使用javascript动态创建script标签引入插件,并执行插件内容

有时候为了避免引入插件过多,需要在代码中根据逻辑判断是否需要引入插件,并运行插件的方法,下面介绍一下使用方式:

  if(location.hostname!=='www.baidu.com'&&location.hostname!=='180.101.50.242'){
    var script = document.createElement('script');
    script.src = '/libs/vconsole.min.js';//也可以是http://www.xxx.cn/xxx.js
    document.head.appendChild(script);
    //下面这两种方式选一种即可,推荐第一种
    //方式一
    setTimeout(function(){new VConsole();}, 500);//需要定时才可以加载完vconsole插件
    //方式二
    setTimeout(() => {
      var jsContent = document.createElement('script');
      jsContent.textContent = 'new VConsole();';
      document.head.appendChild(jsContent);
    }, 500);
  }

    //方式一优化:可以用递归判断VConsole是否存在再实例化VConsole
    var num=0 
    function fn(duration){
      if(window.VConsole){
        new VConsole();
        num=null;
      }else{
        setTimeout(() => {
          num++
          if(num<10*1000/duration){ //10秒钟之内递归
            fn(duration);
          }else{
            num=null
          }
        }, duration);
      }
    }
    fn(200)

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值