在拿出插件之前,先回顾一下apply()的用法,这里和call()做比较。

JavaScript中的每一个Function对象都有一个apply()方法和一个call()方法,它们的语法分别为:

/*apply()方法*/
function.apply(thisObj[, argArray]) /*call()方法*/
function.call(thisObj[, arg1[, arg2[, [,...argN]]]]);

它们各自的定义:

apply:应用某一对象的一个方法,用另一个对象替换当前对象。例如:B.apply(A, arguments);即A对象应用B对象的方法。

call:调用一个对象的一个方法,以另一个对象替换当前对象。例如:B.call(A, args1,args2);即A对象调用B对象的方法。

它们的共同之处:

都“可以用来代替另一个对象调用一个方法,将一个函数的对象上下文从初始的上下文改变为由thisObj指定的新对象”。

它们的不同之处:

apply:最多只能有两个参数——新this对象和一个数组argArray。如果给该方法传递多个参数,则把参数都写进这个数组里面,当然,即使只有一个参数,也要写进数组里。如果argArray不是一个有效的数组或arguments对象,那么将导致一个TypeError。如果没有提供argArray和thisObj任何一个参数,那么Global对象将被用作thisObj,并且无法被传递任何参数。并且apply具有打散参数的作用。

call:它可以接受多个参数,第一个参数与apply一样,后面则是一串参数列表。这个方法主要用在js对象各方法相互调用的时候,使当前this实例指针保持一致,或者在特殊情况下需要改变this指针。如果没有提供thisObj参数,那么 Global 对象被用作thisObj。

实际上,apply和call的功能是一样的,只是传入的参数列表形式不同。

以上只为更好的理解代码,下面看代码:

<script>
//插件
(function () {
/*
* logEl 输出的容器element
* isInitialized 是否初始化
* _console
*/
var logEl,
isInitialized = false,
_console = {}; /*
* 创建元素
* tag 标签名称
* css 样式
*/
function createElement( tag, css ) {
var element = document.createElement( tag );
element.style.cssText = css;
return element;
} /*
* 生成面板
* options 自定义样式对象
*/
function createPanel(options) {
options.bgColor = options.bgColor || 'black';
options.color = options.color || 'lightgreen';
options.css = options.css || '';
var div = createElement( 'div', 'font-family:Helvetica,Arial,sans-serif;font-size:10px;font-weight:bold;padding:5px;text-align:left;opacity:0.8;position:fixed;right:0;top:0;min-width:200px;max-height:50vh;overflow:auto;background:' + options.bgColor + ';color:' + options.color + ';' + options.css);
return div;
} /*
* 日志信息,自定义log方法
*/
function log() {
var el = createElement( 'div', 'line-height:18px;background:' + (logEl.children.length % 2 ? 'rgba(255,255,255,0.2)' : '')); // zebra lines
var val = [].slice.call(arguments).reduce(function(prev, arg) {//
return prev + ' ' + arg;
}, '');
el.textContent = val; logEl.appendChild(el);
// Scroll to last element
logEl.scrollTop = logEl.scrollHeight - logEl.clientHeight;
} /*
* 清空控制台
*/
function clear() {
logEl.innerHTML = '';
} /*
* 初始化插件,可以添加附加选项
*/
function init(options){
if (isInitialized) { return; } isInitialized = true;
options = options || {};
logEl = createPanel(options);
document.body.appendChild(logEl); if (!options.freeConsole) {
// 同步打印更新
_console.log = console.log;
_console.clear = console.clear; console.log = originalFnCallDecorator(log, 'log');
console.clear = originalFnCallDecorator(clear, 'clear');
}
} /*
* 销毁插件并恢复原来的控制台显示
*/
function destroy() {
isInitialized = false;
console.log = _console.log;
console.clear = _console.clear;
logEl.remove();
} /*
* 验证初始化
*/
function checkInitialized(){
if (!isInitialized){
throw 'You need to call `screenLog.init()` first.';
}
} function checkInitDecorator(fn){
return function(){
checkInitialized();
return fn.apply(this, arguments);
};
} /*
* 包含前台打印和后台打印
*/
function originalFnCallDecorator(fn, fnName) {
return function(){
//前台打印
fn.apply(this, arguments);
if (typeof _console[fnName] === 'function') {
//后台打印
_console[fnName].apply(console, arguments);
}
};
} window.screenLog = {
init: init,
log: originalFnCallDecorator(checkInitDecorator(log), 'log'),
clear: originalFnCallDecorator(checkInitDecorator(clear), 'clear'),
destroy: checkInitDecorator(destroy)
};
})(); </script>
<script>
screenLog.init();
screenLog.log('String: Hello world');
screenLog.log(21, 'multiple arguments');
screenLog.log('Arrays', [1, 2, 3]);
console.log('console.log also gets logged.'); var i = 20;
function log() {
console.log('console log', Date.now());
if (--i) { setTimeout(log, 1000); }
}
log();
</script>

运行代码

 使用方法:

1.初始化插件

在页面中引入screenlog.js文件。然后通过下面的方法来初始化该插件。

screenLog.init([option]); 

初始化方法有一个附加选项option:

color:可自定义文本颜色

bgColor:可自定义背景颜色

freeConsole:默认情况下console.log会被在屏幕上重写。你可以通过设置freeConsole为true,并使用screenLog.log() api来避免这种情况的发生。默认为false

2.screenLog.log(obj1[,obj2,obj2...,objn])

在屏幕上显示的log信息。

obj1...objn:要被输出的一组JavaScript对象或字符串。

3.screenLog.clear()

清空屏幕上的log信息。

4.screenLog.destory()

销毁插件并恢复原来的控制台显示。

将控制台信息显示在前台页面的js插件的更多相关文章

  1. javascript笔记——点击按钮(或超链接)如何跳转到另外一个页面并执行目标页面的js函数

    页面跳转同时执行js代码$(function(){});url参数传递 标题的前半部分其实不必赘述,按钮也可以换成超链接.. 假设是需要在A页面上的一个按钮,点击后跳转到B页面,传一些参数后且并B页面 ...

  2. thinkphp在前端页面的js代码中可以使用 U方法吗? 可以使用模板变量如__URL__等吗?

    thinkphp在前端页面的js代码中可以使用 U方法吗? : 可以的! tp的U方法, 是"全局的", 什么是全局的? 就是, 可以在 "任何地方"使用的: ...

  3. 域名ip自动跳转 跳转指定页面的js

    域名ip自动跳转 跳转指定页面的js 为了应对百度审核,需要客户的网站在个别地区跳转到另一个页面,就搞到了这段代码,屡试不爽,超实用.下面把地址换成你要访问的网站url地址或者文件url地址即可.超实 ...

  4. 关于前台jsp页面的js取值问题

    在后程序中传一个字符串到前台页面上,后台代码model.addAttribute("ccc", "cccc"); 在页面js上用下面两种方法取值 1. var ...

  5. 调用上一个页面的js方法

    点击商品分类,弹出下框 点击确定,将选中的类别的name和唯一的code返回到上个页面 function save(){ var ids = getIdSelections(); jp.get(&qu ...

  6. 引用公共页面的js函数报错

    对于网站来说很多页面之间都有着大量的共享模块,如页头,页脚和用户栏等.很多时候为了方便.省事,我们在公共模块写函数,然后在别的页面里调用.但我们在引用公共的js函数时,有些可以引用,有些却报错:这是因 ...

  7. 模式窗体中调用父页面js与非模式化调用非父页面的js方法

    最近项目中使用模式窗体,遇到以下问题记录一下: 模式窗体:你必须关闭该窗体,才能操作其它窗体:比如说,必须按确定或取消,或者按关闭. 非模式窗体:不必关闭该窗体,就可转换到其它窗体上进行操作. 一:非 ...

  8. hexo的next主题博客中加入分类页面的js,实现多级目录,并且能够点击展开,隐藏下级目录~(不知道算不算深度优化~~~)

    个人博客:https://mmmmmm.me 源码:https://github.com/dataiyangu/dataiyangu.github.io 多级标题 在自己的xxxx.md文件中做如下修 ...

  9. 使用内部Servlet转发JSP后页面的JS,CSS等资源引入问题的解决

    转载自:https://blog.csdn.net/weixin_44353336/article/details/90677792 问题原因 我们在进行web项目开发过程中,经常会在web页面引入一 ...

随机推荐

  1. 腾讯云开放云压测“黑科技“,产品上线从此不再“压力山大"

    商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. 能否解决"高并发"问题一直是检验一个产品后台是否稳定,架构是否合理,性能是否强大的核心标准.对于产品而言,多高的并发 ...

  2. 将java项目打包成docker镜像

    简介:将jar打包成镜像好说,毕竟jar包长的都是一样的,但是我们只是写了一个普通的java项目,我也不方便封装成jar包什么的,但是我们也想打包docker image怎么办呢,我们可以用编译后的j ...

  3. OC学习14——谓词

    一.谓词的基本概念与使用 1.谓词(NSPredicate)用于定义一个逻辑条件,通过该条件可执行搜索或内存中的过滤操作.上一篇文章中介绍的集合都提供了使用谓词对集合进行过滤的方法.OC中的谓词操作是 ...

  4. ArcGIS API for JavaScript 4.2学习笔记[13] Layer的弹窗(PopupTemplate)

    上一篇文章中讲到Popup是一个弹窗,是View对象的默认内置弹窗,并且在View对象构造时就顺便构造了. 那么这个PopupTemplate是什么呢? 后半截单词Template是"模板& ...

  5. Android:Error:Execution failed for task ':app:transformResourcesWithMergeJavaResForDebug'.

    今天开发Android项目时,导入了http有关架包后,程序编译报错如下: Error:Execution failed for task ':app:transformResourcesWithMe ...

  6. Java自己动手写连接池二

    读取数据库文件,来操作: package com.kama.cn; import java.sql.Connection;import java.sql.DriverManager;import ja ...

  7. vue基础学习(二)

    02-01  vue事件深入-传参.冒泡.默认事件 <div id="box"> <div @click="show2()"> < ...

  8. Javascript高级程序设计笔记 <第五章> 引用类型

    一.object类型 创建object实例的方式有两种: //第一种使用new操作符跟构造函数 var person= new Object(); person.name="小王" ...

  9. Java Web高级编程(三)

    使用过滤器改进应用程序 一.过滤器的目的 过滤器是可以拦截访问资源的请求.资源的响应或者同时拦截两者的应用组件.过滤器可以检测和修改请求和响应,同时也可以拒绝.重定向或转发请求.javax.servl ...

  10. 进程管理工具Supervisor(二)Events

    supervisor可以当做一个简单的进程启动.重启.控制工具使用,也可以作为一个进程监控框架使用,作为后者,需要使用supervisor的Events机制. Event Listeners supe ...