五个JavaScript 应用技巧

一、阻止别人在Iframe中加载你的页面

如果你的网站变得非常有人气的时候,就有很多网站想链接到你的网站,甚至想把你的网页通过IFrame嵌入它自己的网页。 这样就不好玩了,那么如何来阻止这样行为呢?

ini 复制代码
    if(top !== window) {
     top.location.href = window.location.href;
    }

二、函数中的预定义变量arguments并非一个真正的数组,而是一个类似数组的对象。

它具有length属性,但是没有slice, push, sort等函数,那么如何使arguments具有这些数组才有的函数呢? 也就是说如何使arguments变成一个真正的数组呢?

scss 复制代码
    function args() {
        return [].slice.call(arguments, 0);
    }
    args(2, 5, 8); // [2, 5, 8]

三、为IE添加console.log函数

在Firefox下并有Firebug的支持下,我们经常使用console.log来在控制台记录一些信息。 但是这种做法在IE下会阻止JavaScript的执行(在Firefox下没有启用Firebug情况下也是一样),因为此时根本没有console对象存在。 我们可以通过如下小技巧来防止这样情况的发生:

javascript 复制代码
    if (typeof(console) === 'undefined') {
        window.console = {
            log: function(msg) {
                alert(msg);
            }
        };
    }
    console.log('debug info.');

四、快速字符串连接

我们经常使用+将较短的字符串连接为一个长字符串,这在大部分的情况下是没问题的。 但是如果有大量的字符串需要连接,这种做法将会遇到性能问题,尤其是在IE下。

ini 复制代码
    var startTime = new Date();
    var str = '';
    for (var i = 0; i < 50000; i++) {
        str += i;
    }
    alert(new Date() - startTime);  // Firefox - 18ms, IE7 - 2060ms
    
    var startTime = new Date();
    var arr = [];
    for (var i = 0; i < 100000; i++) {
        arr.push(i);
    }
    var str = arr.join("");
    alert(new Date() - startTime); // Firefox - 38ms, IE7 - 280ms

可以看到Firefox似乎对+操作符进行了优化,而IE则表现的傻乎乎的。

五、闭包(closure)

闭包指的是函数内的局部变量,当函数返回时此变量依然可用。 当你在函数内部定义另外一个函数时,你就创建了一个闭包

scss 复制代码
    function add(i) {   
        return function() {   
            return ++i;   
        };   
    }   
    add(2).toString(); // "function () { return ++i; }"   
    add(2)(); // 3

add(2)是一个函数,它可能获取外部函数的局部变量i。

相关推荐
Stevetagelian23 分钟前
vue2实现元素拖拽
前端·javascript·css·vue.js
西哥写代码28 分钟前
基于cornerstone3D的dicom影像浏览器 第二十一章 显示DICOM TAGS
前端·javascript·vue
Micro麦可乐1 小时前
前端图片裁剪上传全流程详解:从预览到上传的完整流程
前端·javascript·图片上传·图片裁切·cropper.js
Python私教4 小时前
PrimeVue菜单组件深度解析:构建高效能的Web导航系统
前端·javascript·vue.js
黑匣子~6 小时前
Vue 3 官方 Hooks 的用法与实现原理
前端·javascript·vue.js
霍志杰8 小时前
iframe加载或者切换时候,短暂的白屏频闪问题解决
前端·javascript·chrome
愛芳芳10 小时前
vue3+element-plus+pinia完整搭建好看简洁的管理后台
前端·javascript·vue.js
麻辣香蝈蝈10 小时前
【Vue3】一文学会动态路由和编程式路由的使用
开发语言·前端·javascript·vue.js
magic 24511 小时前
AJAX get请求如何提交数据呢?
前端·javascript·ajax
i1yo_kiki12 小时前
Ajax快速入门教程
前端·javascript·ajax