jQuery-Object不';在IE8中不支持此属性或方法

jQuery-Object不';在IE8中不支持此属性或方法,jquery,internet-explorer-8,Jquery,Internet Explorer 8,我在我的一个项目中实现了便笺功能,我发现了一个与浏览器兼容性相关的问题。我的代码在IE8中不起作用,但在其他浏览器中效果很好 我得到的错误是: Message: Object doesn't support this property or method Line: 45 Char: 3 Code: 0 URI: http://dev.mesocial.co/orange_theme/js/sticky_note_func.js 这些是40号到50号之间的线: var moved = func

我在我的一个项目中实现了便笺功能,我发现了一个与浏览器兼容性相关的问题。我的代码在IE8中不起作用,但在其他浏览器中效果很好

我得到的错误是:

Message: Object doesn't support this property or method
Line: 45
Char: 3
Code: 0
URI: http://dev.mesocial.co/orange_theme/js/sticky_note_func.js
这些是40号到50号之间的线:

var moved = function(note) {

    // added by rupesh 
    // alert(JSON.stringify(lastCreatedNoteId)); 
    var passId = note.id
    if(lastCreatedNoteIdForJs.indexOf(note.id) != -1)
         passId = lastCreatedNoteId[note.id];
    // till here ///////
    $.post(SITE_URL+'/dashboard/create-sticky-note/act/moved/sticky_note_id/'+passId+'/pos_x/'+note.pos_x+'/pos_y/'+note.pos_y,
    function(data) {
        //alert(data);
    });
如果您能帮助解决问题,我们将不胜感激。

IE8不支持。在InternetExplorer中,它首先是随着IE9引入的

因为您使用的是jQuery,所以可以改用该方法

在你的例子中,类似这样的情况:

if($.inArray(note.id, lastCreatedNoteIdForJs) != -1)
支持不带jQuery的旧浏览器:

如果您还想在旧式浏览器中使用
.indexOf()
,则可以在需要时使用自己的阵列原型。原型应该是这样的:

if (!Array.prototype.indexOf) {
  Array.prototype.indexOf = function (searchElement /*, fromIndex */ ) {
    "use strict";
    if (this == null) {
      throw new TypeError();
    }
    var t = Object(this);
    var len = t.length >>> 0;

    if (len === 0) {
      return -1;
    }
    var n = 0;
    if (arguments.length > 1) {
      n = Number(arguments[1]);
      if (n != n) { // shortcut for verifying if it's NaN
        n = 0;
      } else if (n != 0 && n != Infinity && n != -Infinity) {
        n = (n > 0 || -1) * Math.floor(Math.abs(n));
      }
    }
    if (n >= len) {
      return -1;
    }
    var k = n >= 0 ? n : Math.max(len - Math.abs(n), 0);
    for (; k < len; k++) {
      if (k in t && t[k] === searchElement) {
        return k;
      }
    }
    return -1;
  }
}
if(!Array.prototype.indexOf){
Array.prototype.indexOf=函数(searchElement/*,fromIndex*/){
“严格使用”;
if(this==null){
抛出新的TypeError();
}
var t=对象(本);
var len=t.length>>>0;
如果(len==0){
返回-1;
}
var n=0;
如果(arguments.length>1){
n=数量(参数[1]);
if(n!=n){//验证是否为NaN的快捷方式
n=0;
}else如果(n!=0&&n!=无穷大&&n!=-无穷大){
n=(n>0 | |-1)*数学地板(数学abs(n));
}
}
如果(n>=len){
返回-1;
}
var k=n>=0?n:Math.max(len-Math.abs(n),0);
对于(;k

上面的示例取自on
Array.prototype.indexOf

检查此链接,它可能会帮助您。。。 IndexOf仅在某些浏览器中有效


IE<9不支持数组的.indexOf方法

jQuery有一个方法,允许您检查元素是否在数组中

if($.inArray(note.id, lastCreatedNoteIdForJs) !== -1) {
    passId = lastCreatedNoteId[note.id];   
}
您还可以将该方法添加到数组对象:

if(!Array.prototype.indexOf){
Array.prototype.indexOf=函数(obj,start){
对于(var i=(start | | 0),j=this.length;i
@Ektapel很高兴它成功了!你应该考虑通过点击那个问题的左边的复选标记来接受对你最有用的答案。你可以阅读更多关于为什么你应该接受答案的内容。
if (!Array.prototype.indexOf) {
    Array.prototype.indexOf = function(obj, start) {
        for (var i = (start || 0), j = this.length; i < j; i++) {
            if (this[i] === obj) { return i; }
        }
        return -1;
    }
}