微软 JScript 运行时错误:对象不支持属性或方法“dialog”。

5
我正在使用一个 .ascx 用户控件,其中我填充了员工数据以及员工图片。 在单击员工图片时,我想显示一个对话框,其中我需要有一个文本字段和一个文本框来从用户那里输入。点击事件可以正常触发,但是出现了“Microsoft JScript runtime error: Object doesn't support property or method 'dialog'”的错误。请问有谁能帮我弹出一个带有文本字段和文本框的对话框?我真的很新JQUERY,并且努力让它工作。
在以下代码片段中,我添加了一个在线示例中的对话框代码。
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="OpenAccessDataProvider,a4a794260c0b4440b466f75d11146db8.ascx.cs" Inherits="SitefinityWebApp.SfCtrlPresentation.OpenAccessDataProvider_a4a794260c0b4440b466f75d11146db8" %>
<%@ Register TagPrefix="sf" Namespace="Telerik.Sitefinity.Web.UI.PublicControls.BrowseAndEdit" Assembly="Telerik.Sitefinity" %>
<%@ Register TagPrefix="sf" Namespace="Telerik.Sitefinity.Web.UI.ContentUI" Assembly="Telerik.Sitefinity" %>
<%@ Register TagPrefix="sf" Namespace="Telerik.Sitefinity.Web.UI.Comments" Assembly="Telerik.Sitefinity" %>
<%@ Register TagPrefix="sf" Namespace="Telerik.Sitefinity.Web.UI.Fields" Assembly="Telerik.Sitefinity" %>
<%@ Register TagPrefix="sf" Namespace="Telerik.Sitefinity.Web.UI" Assembly="Telerik.Sitefinity" %>
<%@ Register TagPrefix="telerik" Namespace="Telerik.Web.UI" Assembly="Telerik.Web.UI" %>

<telerik:RadListView ID="dynamicContentListView" ItemPlaceholderID="ItemsContainer" runat="server" EnableEmbeddedSkins="false" EnableEmbeddedBaseStylesheet="false">
    <LayoutTemplate>
        <ul class="sfitemsList sfitemsListTitleDateTmb">
            <asp:PlaceHolder ID="ItemsContainer" runat="server" />
        </ul>
    </LayoutTemplate>

        <ItemTemplate>
      <li class="sfitem sfClearfix">
            <h2 class="sfitemTitle">
                <sf:DetailsViewHyperLink ID="DetailsViewHyperLink" TextDataField="Title" runat="server" />
            </h2>
           <sf:AssetsField ID="AssetsField1" runat="server" DataFieldName="Picture" />
           <sf:SitefinityLabel ID="SitefinityLabel1" runat="server" Text='<%# Eval("Designation")%>'  WrapperTagName="div" HideIfNoText="true" CssClass="sfitemShortTxt" />           
          <sf:SitefinityLabel ID="SitefinityLabel2" runat="server" Text='<%# Eval("CompanyName")%>' WrapperTagName="div" HideIfNoText="true" CssClass="sfitemShortTxt" />
          <sf:AssetsField ID="AssetsField2" runat="server" DataFieldName="Documents"/>
      </li>
    </ItemTemplate>
</telerik:RadListView>

<sf:Pager id="pager" runat="server"></sf:Pager>

<script type="text/javascript">
    $(document).ready(function () {
        $(".sfClearfix .sfimageWrp img").click(function () {

//            $(document).ready(function () {
                var $dialog = $('<div></div>')
        .html('This dialog will show every time!')
        .dialog({
            autoOpen: false,
            title: 'Basic Dialog'
        });

                $('#opener').click(function () {
                    $dialog.dialog('open');
                    // prevent the default action, e.g., following a link
                    return false;
                });
//            });

            //alert("HEY THERE " + $(this).attr("src")); 
        });
    });
</script>

Regards.

似乎jquery ui.js没有被加载,请记得在包含任何其他库之前先包含jquery.js。 - Rafay
感谢您的建议3nigma。我知道jquery.js没有包含在我的代码中,但正如我所提到的,我正在使用用户控件(.ascx文件)进行工作,在那里我不知道是否允许添加jquery.js脚本,就像我们在.aspx页面的头部添加任何脚本一样,而在用户控件中我没有任何头部。对此有什么建议吗?我尝试直接添加脚本,但仍然遇到相同的错误“Microsoft JScript运行时错误:对象不支持属性或方法'dialog'”。 - Learning Curve
这是与Telerik库的某种烦人冲突。 - Jagd
3个回答

7

各位,我已经搞定了。只需添加一个对话框的div,然后从图片单击中调用该div即可。此外,添加了JQuery.noConflict();以防止Sitefinity和JQuery库之间的任何冲突。以下是代码片段:

<div class="dialogTest"> <br />
<br />
Please enter your email address: <input type="text" name="emailAddress" style="width:300px;" /><br /><br />

<asp:TextBox ID="txtBox" runat="server"></asp:TextBox> <br/>
<asp:Button ID="Button1" runat="server" Text="Button" CausesValidation="False" 
        onclick="Button1_Click" />
</div>

<script type="text/javascript">
$j = jQuery.noConflict();
$j(document).ready(function () {
    $j(".sfClearfix .sfimageWrp img").click(function () {
        $j(".dialogTest").addClass("open");
        //return $j(this).attr("src");
    });
});
</script>

恭喜修复成功!当您有时间时,请确保将您的答案标记为“已接受”,以便其他人能够从您的成功中学习。干杯~ - Andrew Kozak
在telerik和jquery之间发生了一些冲突,导致jquery ui对话框会抛出错误。$j = jQuery.noConflict(); 对我有用。 - desiguy

2
在我的情况下,jquery文件没有正确加载。所以我做了以下几点: 1)在Chrome浏览器中打开页面 2)从菜单或Ctrl+Shift+I中选择开发者工具 3)点击“网络”以查看所有内容。

1
我曾经遇到过同样的问题。问题在于我加载了两个Jquery文件:jquery-1.8.3.js和jquery-1.4.1.js。因此发生了冲突。删除jquery-1.4.1.js文件后,问题得到了顺利解决。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接