3

这是我在这里的第一篇文章,尽管我浏览了很多答案。我遇到了一个问题,IE8 将继续抛出“Object Expected”错误。我使用了 IE8 的开发者工具,它指向“mymh.js”文件

    <script type="text/javascript" src="http://code.jquery.com/jquery-1.7.2.min.js"></script>
    <script type="text/javascript" src="/MyMHome/javascript/mymh.js"></script> 

mymh.js 文件只有以下代码

    $(document).ready(function() {          

        $('#hNumber').focus();

        $('#ddlDir').change(function () {

            var selVal = $('#ddlDir').val();

             if (selVal == 'N' || selVal == 'S' || selVal == 'E' || selVal == 'W'){

             $.getJSON('/MyMHome/DimeServlet?strDir='+$('#ddlDir option:selected').val(), function(data) {

                    $('#ddlSt')
                    .find('option')
                    .remove()
                    .end()

                $.each(data, function(i,field){
                    var name = field;
                    $('#ddlSt')

                    .append('<option value= ' + '"' + name + '"' + '>' + name + '</option>');   
                    });
                });

                $('#ddlSt').focus();    
             }else{ 

                    $('#ddlSt')
                    .find('option')
                    .remove()
                    .end()
                    .append('<OPTION selected value="">Choose a direction first</OPTION>');

                }                   
        })
        .trigger('change');             

        $('#reset').click(function(){
             $('#ddlSt')
            .find('option')
            .remove()
            .end()
            .append('<OPTION selected value="">Choose a direction first</OPTION>'); 
             $('#hNumber').focus();                
        });

        $('#hNumber').bind('keyup', function() {
            if($('#hNumber').val().length == 5){
                    $('#ddlDir').focus();
            }
        });             

        $('#submitQuery').click(function(){
            var houseNumber = $('#hNumber').val();
            if(houseNumber.replace(/\s+/g, '').length == 0){
                alert('Please enter a house number.');
                $('#hNumber').focus();  
                return false;
            }else if( (!$.isNumeric(houseNumber)) || houseNumber.indexOf('-') > -1 || houseNumber.indexOf('.') > -1){
                alert('Please enter numbers only. You will be prompted later, if the address requires a suffix.');
                $('#hNumber').focus();  
                return false;
            }else if(houseNumber < 100 || houseNumber > 12999){
                alert('Please enter a house number between 100 and 12999');
                $('#hNumber').focus();
                return false;
            }else if($('#ddlDir option:selected').val() == 'none'){
                alert('Please select a street direction.');
                $('#ddlDir').focus();
                return false;
            }       
        });         

        $('form').keypress(function(e) {
              if (e.keyCode == '13') {
                 e.preventDefault();
                 if($('#ddlSt').is(":focus")){
                     $('#submitQuery').trigger('click');
                 }
                 else{
                     return false;
                 }
               }
        });
});

错误指向<script ... mymh.js></script>但在调试器中它指向$document.ready(function() {

任何人都认为为什么 IE8 会继续抛出该错误有什么问题?

4

5 回答 5

7

尝试在第 16 行末尾放置一个分号

$('#ddlSt')
.find('option')
.remove()
.end()

$.each(data, function(i,field){

$('#ddlSt')
.find('option')
.remove()
.end();

$.each(data, function(i,field){
于 2012-05-09T23:21:58.447 回答
4
$(document).ready(function() { });  

由于以下原因,此语句可能会引发 Object Expected 错误:

首先,如果我们指向外部 javascript 文件(例如 jquery-1.8.2.min.js)的链接不正确。确保您的链接位于正确的路径。我将文件保存在“js”文件夹中,并将路径指定为:

<script type="text/javascript" src="js/jquery-1.8.2.min.js"></script>  

其次,如果我们将脚本标签写为:

<script type="application/javascript"></script>  

代替

<script type="text/javascript"></script> 
于 2012-11-01T21:51:17.523 回答
4

我在 IE8 中使用 jQuery 2.0.0 时遇到了这个问题。根据 jQuery 站点“jQuery 2.x 不支持 Internet Explorer 6、7 或 8”。用 jQuery 1.10.2 替换 jQuery 2.0.0 为我解决了这个问题。

于 2013-10-17T19:48:49.090 回答
3

有点旧的帖子,但它可能对路过的人有用,我遇到了同样的问题,我删除了脚本标签中的 defer 属性。

<script type="text/javascript" defer="defer" src="js/libs/jquery-1.8.3.min.js"></script>

进入:

<script type="text/javascript" src="js/libs/jquery-1.8.3.min.js"></script>

这对我有用。

于 2013-03-18T14:30:52.593 回答
3

这可能无关紧要,但我刚刚解决了与 IE8 相同的问题 - 代码在 IE9 上运行良好,而在 IE8 上其他所有内容都阻塞了。

答案就像改变一样简单

 <script type="text/javascript" src="/myjavascript.js"></script> 
 <script type="text/javascript" src="http://code.jquery.com/jquery-1.7.2.min.js"></script>

<script type="text/javascript" src="http://code.jquery.com/jquery-1.7.2.min.js"></script>
<script type="text/javascript" src="/myjavascript.js"></script> 

...换句话说,首先是 JQuery。这为我解决了问题;YMMV。

于 2013-08-23T09:52:23.527 回答