我有以下代码:
var currentServerlist = [];
var newServerIp = document.getElementById('add_server').value;
if( CurrentServerIP != newServerIp )
{
$('#failoverServers td.row_selector').each(function() {
var row = $(this).closest('tr');
var serverIp = row.find('td[rel=ip]').text();
currentServerlist.push(serverIp);
});
if(currentServerlist.lastIndexOf(newServerIp) != -1)
{
return true;
}
return false;
}
但是我发现lastIndexOf在InternetExplorer中不起作用(在Chrome中也是如此)。
我该如何解决这个问题?
答案 0 :(得分:7)
根据ES5 compatability table,除IE8及以下版本的所有浏览器均支持Array.prototype.lastIndexOf
。
如果您需要支持此类浏览器,可以使用可用的polyfills之一(或more complete ES5 polyfill solution)。
答案 1 :(得分:1)
某些浏览器(IE)不支持很多JavaScript属性。我通常在mdn上找到解决方案:
https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Array/lastIndexOf
那里的代码:
if (!Array.prototype.lastIndexOf)
{
Array.prototype.lastIndexOf = 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 = len;
if (arguments.length > 1)
{
n = Number(arguments[1]);
if (n != n)
n = 0;
else if (n != 0 && n != (1 / 0) && n != -(1 / 0))
n = (n > 0 || -1) * Math.floor(Math.abs(n));
}
var k = n >= 0
? Math.min(n, len - 1)
: len - Math.abs(n);
for (; k >= 0; k--)
{
if (k in t && t[k] === searchElement)
return k;
}
return -1;
};
}
答案 2 :(得分:0)
lastIndexOf似乎只在IE9 / 10中实现。您需要使用垫片来支持它。请参阅:ES5-shim,特别是509-535行。