今回は、IEでeasyuiが互換性がない問題を解決する方法と、IEでeasyuiが互換性がない問題を解決するための注意事項を紹介します。実際のケースを見てみましょう。
数日前、プロジェクトは起動準備の最終段階に入りましたが、そのテストで、easyui の datetimebox プラグインを使用して取得した時刻が、IE の現在時刻よりも遠いことが判明しました。 time:
$(selector).datetimebox( { formatter : function(date) { var y = date.getFullYear(); var m = date.getMonth() + 1; var d = date.getDate(); var h = date.getHours(); //获取当前小时数(0-23) var mi = date.getMinutes(); //获取当前分钟数(0-59) var s = date.getSeconds(); var result = y + '-' + (m < 10 ? '0' + m : m) + '-' + (d < 10 ? '0' + d : d) + " " + (h < 10 ? '0' + h : h) + ":" + (mi < 10 ? '0' + mi : mi); //console.log(result+"--第127行"); if(second==false){ } else { result += ":" + (s < 10 ? '0' + s : s); } return result; }, parser : function(s) { var t = Date.parse(s); if (!isNaN(t)) { return new Date(t); } else { return new Date(); } } });
Google のテスト ブラウザやその他の主流ブラウザでは問題なく表示され、時刻も選択できますが、Internet Explorer を使用すると、時刻と時刻を選択できません。エコーされた日付は常に現在時刻です。長い間デバッグした結果、ie ブラウザ が js の parse() メソッドをサポートしていないことがわかりました。 parse() メソッドは日付を解析し、日付のミリ秒に変換します。
フォーマッターは日付をフォーマットするためのフォーマットです。そして、パーサーはフォーマットされた日付を解析します。具体的な書き込み方法については、私がキャプチャした API 図を参照してください:
IE では解析が使用できないため~その結果、フォーマットされた日付を解析して表示することができません。 IEの日付。以下は私が自分で変更したコードです:
$(selector).datetimebox( { formatter : function(date) { var y = date.getFullYear(); var m = date.getMonth()+1; var d = date.getDate(); var h = date.getHours(); var min = date.getMinutes(); return y+'-'+(m<10?('0'+m):m)+'-'+(d<10?('0'+d):d)+' '+(h<10?('0'+h):h)+':'+min; }, parser : function(s) { var ss = (s.split(" ")); var ymd = ss[0].split("-"); var hms = ss[1].split(":"); //console.log(ymd+" "+hms); var y = parseInt(ymd[0],10); var m = parseInt(ymd[1],10); var d = parseInt(ymd[2],10); var h = parseInt(hms[0],10); var min = parseInt(hms[1],10); if (!isNaN(y) && !isNaN(m) && !isNaN(d) && !isNaN(h) && !isNaN(min)){ return new Date(y,m-1,d,h,min); } else { return new Date(); } } });
formatter フォーマットされた日付は xxxx-xx-xx xx:x です。したがって、以下を解析する場合、日付と時刻は最初にスペースで区切られます。 ss[0]==xxxx-xx-xx、ss[1]==xx:xx。この場合、- と: を介して数値に分割します。この場合、正しい日付形式を new Date() のパラメーターに直接書き込むことで返すことができます~~ まあ、テストした結果、この不正行為と完全に互換性があります。 IEブラウザ。
今日このメソッドを使用しているときに突然バグを発見しました。つまり、最初の日時フレームにデータがないと分割エラーが報告されるということです。そこで、今日それを修正して空のメソッドを追加しました判定:
if(s==""){ return new Date(); }else{ //alert(s); var ss = (s.split(" ")); var ymd = ss[0].split("-"); var hms = ss[1].split(":"); //console.log(ymd+" "+hms); var y = parseInt(ymd[0],10); var m = parseInt(ymd[1],10); var d = parseInt(ymd[2],10); var h = parseInt(hms[0],10); var min = parseInt(hms[1],10); if (!isNaN(y) && !isNaN(m) && !isNaN(d) && !isNaN(h) && !isNaN(min)){ return new Date(y,m-1,d,h,min); } else { return new Date(); } }
ここにあります s は string 型であることに注意してください~そのため、判定条件として s==null を使用することはできません~
この記事の事例を読んだ後は、この方法を習得したと思います。興味深い情報が満載です。PHP 中国語 Web サイトの他の関連記事にもご注目ください。
推奨読書:
以上がIEのeasyuiの非互換性を解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。