zoukankan      html  css  js  c++  java
  • 移动端调试利器-vConsole

    现在移动端开发越来越火,随之而来的问题也越来越多,今天给大家介绍一款移动端调试神器,vconsole。

    一、先引用文件,可以从https://www.bootcdn.cn/vConsole/下载,也可以下载保存在本地,直接引用

      <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>demo.html</title>
        <script src="https://cdn.bootcss.com/vConsole/3.3.0/vconsole.min.js"></script>
    </head>
    <body>
        <script type="text/javascript">
            let vConsole = new VConsole();
        </script>
    </body>
    </html>
    

    浏览器显示如下:

    基本的一些用法,大家可以上网查找,我着重写一下我在配置时候的一些小问题

    首先我们是一个成熟的项目,而且我想在整个页面里面都引用整个方法,显然每个页面直接引用再实例化不怎么合适,而且工作量有点大,下面是我遇到的一些小坑以及小技巧

    1.我们需要动态添加一个script标签,可以选择原生添加,或者jQuery添加

    原生添加
    function loadJs(url,callback){
             var script1=document.createElement('script');
             script1.type="text/javascript";
             if(typeof(callback)!="undefined"){
                 if(script1.readyState){
                     script1.onreadystatechange=function(){
                          if(script1.readyState == "loaded" || script1.readyState == "complete"){
                              script1.onreadystatechange=null;
                              callback();
                      }
                 }
             }else{
                 script1.onload=function(){
                  callback();
                 }
             }
         }
             script1.src=url;
             document.body.appendChild(script1);
     }
     loadJs("vconsole.min.js",function(){
        let vConsole = new VConsole();
     });
    

    页面里面直接引用js文件,谷歌报错如下

    这是因为js引用位置错误引起的,需要把js文件放置在body里面,不然会加载不到,调换位置,错误完美解决。

    jQuery引入,代码如下,先引用jQuery
    $.getScript('../vconsole.min.js',function(){
        var vConsole = new VConsole(); 
    });
    

    这是同源策略的限制,需要我们本地启动一个服务,来运行这个index文件,

    使用http-server或者xampp都可以,根据个人喜好,这个问题也迎刃而解。

    1. 我们的项目是H5项目,使用的库是zepto,直接引用会报错,说这个$.script这个方法不存在,这样需要我们先往zepto这个库里添加一个$.script方法才可以向上面那样使用,添加方法如下:
    ;
    (function() {
        /**
         * 动态加载js文件
         * @param  {string}   url      js文件的url地址
         * @param  {Function} callback 加载完成后的回调函数
         */
        var _getScript = function(url, callback) {
            var head = document.getElementsByTagName('head')[0],
                js = document.createElement('script');
    
            js.setAttribute('type', 'text/javascript'); 
            js.setAttribute('src', url); 
    
            head.appendChild(js);
    
            //执行回调
            var callbackFn = function(){
                    if(typeof callback === 'function'){
                        callback();
                    }
                };
    
            if (document.all) { //IE
                js.onreadystatechange = function() {
                    if (js.readyState == 'loaded' || js.readyState == 'complete') {
                        callbackFn();
                    }
                }
            } else {
                js.onload = function() {
                    callbackFn();
                }
            }
        }
    
        //如果使用的是zepto,就添加扩展函数
        if(Zepto){
            $.getScript = _getScript;
        }
        
    })();
    

    原文

  • 相关阅读:
    解决本地浏览器的跨域问题
    页面嵌入iframe关于父子传参调用
    仿微信、qq聊天,@好友功能
    创建新react项目 运行npm start 报错踩过的坑
    前端向后端获取数据的三种方法:ajax、axios、fetch
    观察者模式代码详解
    代理模式实现图片预加载、懒加载
    网站登录注册-Session 和token的总结
    浅谈MVC、MVVM的区别
    vue中methods、computed、watch区别
  • 原文地址:https://www.cnblogs.com/kerin/p/15507525.html
Copyright © 2011-2022 走看看