1

私のサイトの Javascript ファイルの 1 つが、iPad (Mobile Safari) の表示を台無しにしています。iPad でのみファイルを削除し、他のすべてのブラウザーに提供したいと考えています。

私は次のJavaScriptを持っています:

<script type="text/javascript">
<![CDATA[
function removejscssfile(filename, filetype){
 var targetelement=(filetype=="js")? "script" : (filetype=="css")? "link" : "none" //determine element type to create nodelist from
 var targetattr=(filetype=="js")? "src" : (filetype=="css")? "href" : "none" //determine corresponding attribute to test for
 var allsuspects=document.getElementsByTagName(targetelement)
 for (var i=allsuspects.length; i>=0; i--){ //search backwards within nodelist for matching elements to remove
  if (allsuspects[i] && allsuspects[i].getAttribute(targetattr)!=null && allsuspects[i].getAttribute(targetattr).indexOf(filename)!=-1)
   allsuspects[i].parentNode.removeChild(allsuspects[i]) //remove element by calling parentNode.removeChild()
 }
}

if((navigator.userAgent.match(/iPad/i)) 
{
  removejscssfile("somescript.js", "js") //remove all occurences of "somescript.js" on page for ipad 
}
]]
</script>

まず、上記の Javascript は有効ですか? (私の知識は浅いです)

第二に、これが最善の方法ですか?

4

2 に答える 2

0

phpなど、これがはるかに簡単な方法を使用していない場合は、逆に、ブラウザがiPadでない場合は、条件付きでファイルをドキュメントの先頭にロードする必要があります。

    function loadjscssfile(filename, filetype) {
            if (filetype == "js") { //if filename is a external JavaScript file

                var fileref = document.createElement('script')
                fileref.setAttribute("type", "text/javascript")
                fileref.setAttribute("src", filename)

            }
            else if (filetype == "css") { //if filename is an external CSS file
                var fileref = document.createElement("link")
                fileref.setAttribute("rel", "stylesheet")
                fileref.setAttribute("type", "text/css")
                fileref.setAttribute("href", filename)
            }
            if (typeof fileref != "undefined")
                document.getElementsByTagName("head")[0].appendChild(fileref)
    }

    var isiPad = navigator.userAgent.match(/iPad/i) != null;

    if (!isiPad) {
        //load js OR css files
    }
于 2012-09-20T00:49:17.447 に答える
0

問題のあるJS関数を見つけて追加することでこれを修正しました:

&& navigator.userAgent.match(/ipad/i) == null

シンプルイズグッド

于 2012-09-21T03:46:25.150 に答える