• 【写一个自己的js库】 2.实现自己的调试日志


       还是本着学习的目的,实现一个自己的调试日志,界面很简单,就是将调试信息显示在页面的正中央,用一个ul包裹,每条信息就是一个li。

       1.新建一个myLogger.js文件,将需要的方法声明一下。其中var声明的是私有成员,可见范围只在构造函数中,每个实例都会保存一套他们的副本。this声明的是特权方法,new的时候会把它绑定到实例上,实例可以直接调用它。在prototype上声明的就是公有方法了,每个实例都可以访问它。最后将一个实例赋值给Lily这个库,Lily就有自己的日志插件了。

    function myLogger(id){
        id = id || 'LilyLogWindow';
        var logWindow = null;
        var createWindow = function (){};
        this.writeRaw = function (){};
    }
    
    myLogger.prototype = {
        write : function (message){},
        header: function (message){}
    };
    
    if(!window.Lily) { window.Lily = {}; }
    window['Lily']['log'] = new myLogger();

        2.先给Lily补充一个方法,因为要显示在页面的中央,所以要获得浏览器窗口的高度和宽度,所以加个getBrowserWindowSize。window.innerWidth和window.innerHeight IE8及之前的版本不支持,document.documentElement在IE6的怪异模式下获取的值不正确。

    function getBrowserWindowSize(){
            var de = document.documentElement;
            return {
                width : window.innerWidth || (de && de.clientWidth) || (document.body.clientWidth),
                height: window.innerHeight || (de && de.clientHeight) || (document.body.clientHeight)
            };
        }
        Lily['getBrowserWindowSize'] = getBrowserWindowSize;

        3.createWindow。这里就设置ul是固定的宽高,这里没用外链css,是因为如果想调试还要加个css,比较麻烦,所以就都在js里写好了。

    var createWindow = function (){
            var windowSize = Lily.getBrowserWindowSize();
            var top = (windowSize.width - 200)/2 || 0;
            var left = (windowSize.height - 200)/2 || 0;
    
            logWindow = document.createElement("ul");
            logWindow.setAttribute("id", id);
    
            logWindow.style.position = "absolute";
            logWindow.style.left = left + "px";
            logWindow.style.top = top + "px";
    
            logWindow.style.width = "200px";
            logWindow.style.height = "200px";
            logWindow.style.overflow = "scroll";
    
            logWindow.style.border = "1px solid #f1f1f1";
            logWindow.style.padding = "0";
            logWindow.style.margin = "0";
            logWindow.style.listStyle = "none";
    
            document.body.appendChild(logWindow);
        };
    View Code

        4.writeRaw,当调用这个方法时,才检查logWindow是否创建,如果没创建,就调用createWindow,注意不要加this,因为createWindow是私有变量,myLogger的实例没有这个方法,而根据闭包,writeRaw可以访问到createWindow。虽然各浏览器都支持innerHTML,但是它不属于w3c规范,所以在用之前要进行一下能力检测,以防以后的浏览器不支持。

    this.writeRaw = function (message){
            if(!logWindow) createWindow();
            var li = document.createElement("li");
    
            li.style.padding = "2px";
            li.style.margin = "0";
            li.style.borderBottom = "1px dotted #f0f0f0";
    
            if(typeof message == "undefined"){
                li.appendChild(document.createTextNode("message is undefined"));
            }else if(typeof li.innerHTML != "undefined"){
                li.innerHTML = message;
            }else{
                li.appendChild(document.createTextNode(message));
            }
    
            logWindow.appendChild(li);
            return true;
        };
    View Code

       5.write和header。这里write要处理一下信息,去掉html格式,不是string类型的调用toString或者显示它的类型。header就是将message包裹一下。

    myLogger.prototype = {
        write : function (message){
            if(typeof message != 'string'){
                if(message.toString){
                    return this.writeRaw(message.toString());
                }else{
                    return this.writeRaw(typeof message);
                }
            }
    
            if(typeof message == 'string' && message.length == 0){
                return this.writeRaw("Lily log : message is null");
            }
    
            message = message.replace(/</g, '&lt;').replace(/>/g, "&gt;");
            return this.writeRaw(message);
    
        },
        header: function (message){
            message = '<span style="color:#fff;background-color:#000;font-weight:bold;padding:0 5px">' + message + '</span>';
            return this.writeRaw(message);
        }
    };
    View Code

       6.测试一下,在一个空白html引入Lily.js, myLogger.js, 写入一些信息。

  • 相关阅读:
    微信开发-Jssdk调用分享实例
    软件工程
    Homework_4 四则运算
    Homework 3
    每周总结
    自动生成四则运算题目
    Homework 1 -- The beginning
    程序员视角的餐饮行业
    iOS9网络适配_ATS:改用更安全的HTTPS
    Xcode的 发展史
  • 原文地址:https://www.cnblogs.com/pandabunny/p/4758121.html
Copyright © 2020-2023  润新知