所以我顯示基於選擇複選框的圖形,並遇到一個小問題。獲取所有的ONE屬性的實例,而不是隻有一個
我目前正在循環並選擇第一個圖表,即使選中全選複選框時也是如此 - 這意味着我得到了許多相同的第一個圖形而不是十個獨特的圖形。
正如您將在下面的代碼中看到的,我用的是以前的行註釋掉:完美在Firefox
//var fnInstance=$('#counterTreeviewUL'+idTreeview)[0].children[i].children[0].attributes[1].value;
只能 - 它會顯示所有圖表正確等,但不工作在Chrome/IE中,由於它嘗試訪問元素的方式。
我與這兩條線取代了它:
$el = $('#counterTreeviewUL'+idTreeview).first();
var fnInstance = $el.find("input").attr("onclick");
我有原因的一切取而代之的是在所有三個瀏覽器功能(在IE或Chrome沒有錯誤了)這兩條線,然而的只有圖中顯示的是第一個找到的 - 如果選擇了三個元素,那麼將顯示第一個圖的3個版本,而不是3個獨特的圖。
完整的代碼的下方,什麼樣的元素包含console.logs是低於:元素
for (var i=0;i<$('#counterTreeviewUL'+idTreeview)[0].children.length;i++)
{
if (!$('#counterTreeviewUL'+idTreeview)[0].children[i].children[0].checked)
{
$('#counterTreeviewUL'+idTreeview)[0].children[i].children[0].checked=true;
//var fnInstance=$('#counterTreeviewUL'+idTreeview)[0].children[i].children[0].attributes[1].value;
$el = $('#counterTreeviewUL'+idTreeview).first();
var fnInstance = $el.find("input").attr("onclick");
fnInstance=fnInstance.substr(15).substr(0,fnInstance.length-2);
var flagsInstance=fnInstance.split(new RegExp(","));
var graph = {
id: seqId,
entityName: flags[6].substr(1).substr(0, flags[6].length - 2),
entity: flags[5].substr(1).substr(0, flags[5].length - 2),
idCounter: flags[4],
counterName: flags[3].substr(1).substr(0, flags[3].length - 2),
ivmanager: flags[7].substr(1).substr(0, flags[7].length - 2),
chart: null,
pointsToShowX: null,
borneInf: null,
unite: "",
idInstance: flagsInstance[2].substr(1).substr(0, flagsInstance[2].length - 2),
instanceName: flagsInstance[3].substr(1).substr(0, flagsInstance[3].length - 2),
listPdsNull: new Array(),
countInstance: idTreeview + "_" + i,
countGraph: -1
};
seqId++;
graphs[graphsLastId]=graph;
graphsLastId++;
}
}
Console.logs:
任何因爲我花了幾個小時試圖解決(另一個以前僱員的)代碼,所以幫助會很大。
我基本上只需要這一行的瀏覽器的版本 -
var fnInstance=$('#counterTreeviewUL'+idTreeview)[0].children[i].children[0].attributes[1].value;
您似乎仍然混合使用jQuery和純DOM方法。 – Bergi
@Bergi這不是我的代碼,我對你爲什麼這樣做是困惑的。我會去改變所有的東西給JQuery,但現在這是唯一的'錯誤'我已經離開和截止日期的調用。 。只是不知道如何以IE和Chrome接受的方式複製註釋行。 – lifetimes
對於開始,您可以使用$('#counterTreeviewUL'+ idTreeview +'input)縮短您的複選框選擇器[類型= 「複選框」]:檢查')'。 – kayen