2017-02-18 39 views
0

我已經加載了下面的jqGrid網格關於汽車年度檢查維護數據。爲什麼react的babel會拋出重複的對象錯誤,IE上的jqgrid?

在鉻這看起來像這樣:

enter image description here

這被作爲反應對象生成,代碼,如下所示:

HTML:

<!DOCTYPE html> 
    <html> 
    <head lang="en"> 
     <meta charset="UTF-8"> 
     <title></title> 
     <link rel="stylesheet" href="https://code.jquery.com/ui/1.12.1/themes/start/jquery-ui.css" /> 
     <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/free-jqgrid/4.13.6/css/ui.jqgrid.min.css" /> 
    </head> 
    <body> 

    <div id="divContainer"></div> 

<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.0.0/react.js"></script> 
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.0.0/react-dom.js"></script> 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.34/browser.min.js"></script> 

    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script> 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script> 
    <script> 
     $.jgrid = $.jgrid || {}; 
     $.jgrid.no_legacy_api = true; 
     $.jgrid.useJSON = true; 
    </script> 

    <script src="https://rawgit.com/free-jqgrid/jqGrid/master/js/jquery.jqgrid.src.js"></script> 

    <script type="text/babel" src="sample.jsx"> 
    </script> 



    </body> 
    </html> 

JSX代碼:

var SampleGrid = React.createClass({ 
    componentDidMount:function(){ 
     this.gridLoad(); 
    }, 
    gridLoad:function(){ 
     var mydata = [ 
      { id: "1", test: "Engine checkup", teststart: "12/12/2016", testend: "12/30/2016", passed: true}, 
      { id: "2", test: "Electrical Checkup", teststart: "1/2/2017", testend: "1/3/2017", passed: false}, 
      { id: "3", test: "Chasis checkup", teststart: "1/4/2017", testend: "1/5/2017", passed: false}, 
      { id: "4", test: "Aerodynamics checkup", teststart: "1/6/2017", testend: "1/9/2017", passed: true}, 
      { id: "5", test: "Balance and stability checkup", teststart: "1/10/2017", testend: "1/12/2017", passed: true}, 
      { id: "6", test: "Report", teststart: "", testend: "", closed: false } 
     ]; 

     jQuery("#grid100").jqGrid({ 
      colNames: ['test','passed','test started','test ended'], 
      colModel: [ 
       {name: 'test', index: 'test', width: 220 }, 
       {name: 'passed', index: 'passed', width: 60, align: 'center', formatter: 'checkbox', 
        edittype: 'checkbox', editoptions: {value: 'Yes:No', defaultValue: 'Yes'}, formatoptions: { disabled: false}, 
        cellattr: function(rowId, tv, rawObject, cm, rdata) { 
         if (Number(rowId) == 6) { return ' colspan="3"' }}, 
        formatter:function(cellvalue, options, rowObject) 
        { 
         if(rowObject.id==6) 
         { 
          return '<input type="text" id="txtnotes" ref="refnotes" />'; 
         } 
         else 
         { 
          if(rowObject.passed===true) 
          { 
           return '<input type="checkbox" id="cbPassed-'+ rowObject.id +'" checked/>'; 
          } 
          else 
          { 
           return '<input type="checkbox" id="cbPassed-'+rowObject.id+ '" />'; 
          } 
         } 
        } 

       }, 
       {name: 'teststart', index: 'teststart', width: 75, formatter: 'string', sorttype: 'string', align: 'center', 
        cellattr: function(rowId, tv, rawObject, cm, rdata) { 
         if (Number(rowId) == 6) { return ' style="display:none;"' }}},//return ' colspan="5"' 
       {name: 'testend', index: 'testend', width: 75, formatter: 'string', sorttype: 'string', align: 'center', 
        cellattr: function(rowId, tv, rawObject, cm, rdata) { 
         if (Number(rowId) == 6) { return ' style="display:none;"' }}} 

      ], 
      rowNum: 10, 
      rowList: [5, 10, 20], 
      threeStateSort:true, 
      gridview: true, 
      rownumbers: false, 
      autoencode: true, 
      ignoreCase: true, 
      sortname: "id", 
      viewrecords: true, 
      sortorder: "desc", 
      shrinkToFit: false, 

     }); 
     for(var i=0;i<=mydata.length;i++) 
      jQuery("#grid100").jqGrid('addRowData',i+1,mydata[i]); 

     jQuery("#grid100").jqGrid('setGroupHeaders', { 
      useColSpanStyle: true, 
      groupHeaders:[ 
       {startColumnName: 'passed', numberOfColumns: 3, titleText: 'Test Duration'} 
      ] 
     }); 
    }, 
    render:function(){ 
     return(<div id="gridContainer" ref="refContainer"> 
       <form> 
        <table id="grid100"></table> 
       </form> 
      </div> 
     ) 
    } 
}) 

ReactDOM.render(<SampleGrid />, document.getElementById('divContainer')); 

但是這表現得很有趣。當我跑在Chrome它運行完美的代碼,但是當我跑這對IE瀏覽器(我的版本是10),它提供了以下錯誤在控制檯上

SCRIPT1046:一個屬性的多個定義不允許嚴格模式

enter image description here

我一時想不通,爲什麼同樣的代碼產生的結果在一個瀏覽器,而不是在另一個。但我知道這個錯誤引發,因爲我已經添加了formater到通過

formatter:function(cellvalue, options, rowObject) 
      { 
       if(rowObject.id==6) 
       { 
        return '<input type="text" id="txtnotes" ref="refnotes" />'; 
       } 
       else 
       { 
        if(rowObject.passed===true) 
        { 
         return '<input type="checkbox" id="cbPassed-'+ rowObject.id +'" checked/>'; 
        } 
        else 
        { 
         return '<input type="checkbox" id="cbPassed-'+rowObject.id+ '" />'; 
        } 
       } 
      } 

如何解決這個問題列

回答

1

問題的原因:對列passed(請參閱formatter: 'checkbox', ..., formatter:function(cellvalue, options, rowObject) {...})使用多個formatter屬性。您應該從代碼中刪除或註釋formatter: 'checkbox'

我建議你另外:

  • 從未填充在循環使用addRowData數據網格。你應該從你的代碼中刪除for(var i=0;i<=mydata.length;i++) jQuery("#grid100").jqGrid('addRowData',i+1, mydata[i]);行。另外,您應該添加data: mydata參數並刪除不需要的sortorder: "desc"選項。
  • colModel
  • 刪除不需要的選項gridview: true, rownumbers: false, ignoreCase: true刪除所有index屬性。所有的值在jqGrid中已經是默認值了。
+0

感謝Oleg,現在網格加載在IE上:) –

相關問題