前后端知识交流分享

通过js代码主动添加js,css文件或字符串

2018-09-26  本文已影响2人  Trytodo_zbs

1.前提

有些时候可能碰到一些特殊情况,需要临时添加一些js,css文件或代码到当前页面
有些时候某些平台如百度地图之类的依赖需要更新文件验证的
有需要动态加载js方法到当前页面的
我们可以使用js来实现这些需求

2.内容

2.1,将string类型代码加入到页面

        scriptString:function(code){
            var script=document.createElement("script");
            script.type="text/javascript";
            try{
                script.appendChild(document.createTextNode(code));
            }catch(ex){
                script.text=code;
            }
            document.body.appendChild(script);
        }

这个比较直接考虑兼容性使用try catch包含两种添加方法

2.2,动态添加js文件

        //将.js文件加载到body元素
        scriptFile:function(url){
            //规定第一个参数为url必须要有
            var args=arguments;
            var len=args.length;
            if(len){
                //可以通过遍历所有script标签替换掉旧有的script文件,主要用于js文件更新
               if(args[1]&&(typeof args[1]=='string')){
                    //取的所有script标签
                    var old=document.getElementsByTagName("script");
                    //遍历  拿新的uri和所有的uri做比较   统一砍掉.js后面的参数
                    for(var i=0,len=old.length;i<len;i++){
                        if(old.item(i).src.substring(0,old.item(i).src.indexOf(".js")+3)==url.substring(0,url.indexOf(".js")+3)){
                            document.body.removeChild(old.item(i));
                        }
                    }
                }
                var script=document.createElement("script");
                script.type="text/javascript";
                script.src=url;
                //添加onload回调
                if(args[1]&&(typeof args[1]=='function')){
                    script.onload=function(){
                        args[1]();
                    }
                }else{
                    if(args[1]&&(typeof args[1]=='string')&&args[2]&&(typeof args[2]=='function')){
                        script.onload=function(){
                            args[2]();
                        }
                    }
                }
                document.body.appendChild(script);
            }else{
                console.error("必须有参数");
            }
        },

通过".js"来截断url路径可以确保大部分情况下正确对比,但也有特殊情况不正确,需要根据实际情况来考虑
添加onload事件以方便某些代码执行在文件加载完成后

2.3,添加string格式的css代码

        styleString:function(css){
            var style=document.createElement("style");
            style.type='text/css';
            try{
                style.appendChild(document.createTextNode(css));
            }catch(ex){
                style.stylesheet.cssText=css;
            }
            var Head=document.getElementsByTagName("head")[0];
            Head.appendChild(style);
        },

这里使用的是document.getElementsByTagName("head")[0];来获取head标签,实际上也可以使用document.head来获取,就是会有一定的兼容性问题
getElementsByTagName这个方法在很低版本的ie浏览器上也会出现不支持的情况,不过现在一般都不考虑

2.4,添加css文件

        styleFile:function(url){
            var head=document.getElementsByTagName('head').item(0);
            var style=document.createElement("style");
            style.type='text/css';
            style.href=url;
            style.rel='stylesheet';
            head.appendChild(style);
        }

实现原理和js文件类似 不过css文件代码不需要onload事件来支撑功能的实现,加载完成后自动生效

3.后记
vue的样式加载应该用到了类似的加载方式,所有的样式都是通过js文件写入到head头部style标签中

加载网络资源的时候可以使用此类方法切换多个来源以确保稳定,当然一般不会碰到这样的需求

上一篇下一篇

猜你喜欢

热点阅读