js一些稀奇古怪的写法-带你装逼带你飞
//定时器的第三个参数
setInterval(function(str1,str2,num){
alert(str1+str2+num)
},1000,'参数1','还可以有很多参数,不同的类型...',123); //控制台输出有样式的文本信息或图片
//大大的中文详细文档http://wayou.github.io/2014/09/10/chrome-console-tips-and-tricks/
console.log('%c这些字是红色的,哈哈','color:red'); //字符串链连接的三种方法
document.body.innerHTML='<div id="content"><p class="abc"></p><span>span</span>...</div>'; // document.body.innerHTML=
'<div id="content">'+
'<p class="abc"></p>'+
'<span>span</span>'+
'...'+
'</div>'; // document.body.innerHTML=
'<div id="content">\
<p class="abc"></p>\
<span>span</span>\
...\
</div>'; //3--狂拽炫酷吊炸天吧 o(≧v≦)o~~注意空格 //跳出嵌套for循环,给for添加个名字,用break跳出指定的for循环
name : for(var i=0; i<5; i++){
for(var j=0; j<1; j++){
if(i==3){
break name;
}
alert(i);
}
} //for的简写,没有条件限制,一直执行,相当于条件一直是true
var num=0;
for(;;){
alert(num);
if(++num>5){ //内部给限制条件,以跳出无限循环
break;
}
} //for的多表达式--for(初始化语句; 条件语句; 控制语句)
for(var i=10,j=10; i>0 && j<15; i--,j++){
alert( 'i='+i+',j='+j )
} //typeof和instanceof等加上小括号的写法,还有的好像in,return
//原因:由于 typeof也可以像函数的语法被调用,比如 typeof(obj),但这并不是一个函数调用。 那两个小括号只是用来计算一个表达式的值,这个返回值会作为 typeof操作符的一个操作数。 实际上不存在名为 typeof的函数。js秘密花园文档--http://bonsaiden.github.io/JavaScript-Garden/zh/#types.typeof
alert( typeof 6 ) //number
alert( typeof(6) ) //number //省略创建对象时的小括号,包括自己创建的构造函数也可以
var arr=new Array();
var arr=new Array; //匿名函数自执行,知乎文档--匿名函数附近使用括号或一些一元运算符的惯用法,就是来引导解析器,指明运算符附近是一个表达式--按照这个理解,可以举出五类,超过十几种的让匿名函数表达式立即调用的写法:--http://www.zhihu.com/question/20249179
( function() {}() );
( function() {} )();
[ function() {}() ]; //小括号或中括号括起来调用 ~ function() {}();
! function() {}();
+ function() {}();
- function() {}(); //位运算符[~!+...]在前,小括号调用 delete function() {}();
typeof function() {}();
void function() {}();
new function() {}();
new function() {}; 1, function() {}();
1 ^ function() {}();
1 > function() {}(); //等等 //改变this指向等相近方法arguments,callee,caller,call,apply的区别
//百度文档--http://wenku.baidu.com/link?url=NPq__nPg_VNrcb89NFPGi_deo-S7EnL1LHgH7qgbUsdpmYLDTtEYzKuh4u8AXZqHNpU3qmp6YgYrSxA12ocB8gJ69scGsosdOS9o5HQzmZS
var obj={
aaa:function(){
alert(this);
},
bbb:function(fn){
fn();
}
}
obj.aaa(); //this指向obj
obj.aaa.call(); //this指向document,无参数默认指向window
//call()和apply()方法的作用相同,区别在与接收参数的方式不一样
obj.bbb(function(){
alert(1);
arguments.callee(); //arguments.callee等于其上面的这个函数,加个()就是让自身函数再次执行
}); //无限弹出1,因为函数每次执行到最后又调用了自身函数--执行
//arguments.length是实参长度,arguments.callee.length是形参长度,由此能够判断调用时形参长度是否和实参长度一致
function a(){
if(a.caller){
alert(a.caller)
}else{
alert('top')
}
}
a(); //弹出top;因为a是最外层函数,此时a.caller为null; function b(){
a();
}
b(); //弹出function b(){a();},因为此时a.caller指向b这个函数体
js一些稀奇古怪的写法-带你装逼带你飞的更多相关文章
- 软件测试工程师人手必备的一只:TOM猫,可以带你装逼带你飞!
Hi,你来了? 其实没有猫,为了让你们好好学习,天天向上!我可真的是拼了命了! 写这篇文章的缘由是,近期有同学经常问到一个这样的问题: 老师,tomcat是啥? 老师,Linux是啥? 老师,xshe ...
- [转载] vim带你装逼带你飞(一)
前言:逃离windows有很长时间了,特别是当今android盛行的时代,我们没有理由不选择ubuntu作为编译开发android之首选.其实操作系统只是我们使用的一个工具, windows也好lin ...
- vim带你装逼带你飞(一)
前言:逃离windows有很长时间了,特别是当今android盛行的时代,我们没有理由不选择ubuntu作为编译开发android之首选.其实操作系统只是我们使用的一个工具, windows也好lin ...
- vim带你装逼带你飞(二)
上篇我贴上了我使用的vim配置及插件配置,有这些东西只能是一个脚本堆积,无从谈高效的代码阅读开发. 下面我们就来写经常使用的命令,就从配置F系列快捷键开始吧. F+ n 快捷键配置 F1基本上时帮助, ...
- JS !function 稀奇古怪的写法
!function(){alert("Execute after ()fun!")}(alert("Execute Firstly!")) 注意上面的执行顺序
- 带你装B,带你飞的大数据时代
我接触过的大数据有: 1.美国棱镜计划 2.前几天新闻报道的,苹果公司窃取用户隐私 3.百度的用户搜素习惯统计分析 4.淘宝的用户购物习惯分析,智能推荐宝贝 5.浏览器的智能标签页 ... 最想了解的 ...
- 你会用Python做出装逼的东西吗
如果我回答:“用Python很牛逼,但不能做出装逼的东西”,那大家来学习“小白的Python入门教程 ”,还有多少意义? 所以,为了让装逼的小船升级为牛逼的巨轮,让大家学完“小白的Python入门教程 ...
- js函数的各种写法与调用
以下是我见过的各种js函数的各种写法以及调用,虽然有些写法及其调用我不清楚其专业术语叫啥,但并不影响我写一个总结笔记. 我们刚开始接触js语音,经常看到的这种名叫“使用function关键字来定义函数 ...
- js函数常见的写法以及调用方法
写在前面:本文详细的介绍了5中js函数常见的写法以及调用的方法,平时看别人代码的时候总是看到各种不同风格的js函数的写法.不明不白的,找了点资料,做了个总结,需要的小伙伴可以看看,做个参考.1.常规写 ...
随机推荐
- namespace用法
1.在WCF.Controller中定义了一个UserModel,标记为① 2.在WCF.Controller.Model中定义了一个UserModel(同上,namespace不同),标记为② 3. ...
- flexgrid的应用
第一.导入必须的CSS与JS: <link rel="stylesheet" type="text/css" href="css/flexigr ...
- 《Head First 设计模式》ch.1 策略(Strategy)模式
策略模式 定义了算法族,分别封装起来,让它们可以互相替换,让算法的变化独立于使用算法的客户. 模式名词的意义 威力强大,交流的不止是模式名称,而是一整套模式背后所象征的质量.特性.约束 用更少的词汇做 ...
- Codeforces Round #218 (Div. 2) C. Hamburgers
C. Hamburgers time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- java数据结构之列表——ArrayList,LinkedList,比较
刚看完<数据结构与算法分析java语言描述>的第3章中的表,下面回忆下主要知识点,主要说明各列表之间的关系,以及各自的优缺点.其中牵涉到内部类和嵌套类. 1 Collection APIp ...
- 【Unity Shaders】学习笔记——SurfaceShader(六)混合纹理
[Unity Shaders]学习笔记——SurfaceShader(六)混合纹理 转载请注明出处:http://www.cnblogs.com/-867259206/p/5619810.html 写 ...
- autoit UIA获取Listview的信息
#include "CUIAutomation2.au3" Opt( ) Global $oUIAutomation MainFunc() Func MainFunc() ; Be ...
- memcached学习(5). memcached的应用和兼容程序
mixi在提供服务的初期阶段就使用了memcached. 随着网站访问量的急剧增加,单纯为数据库添加slave已无法满足需要,因此引入了memcached. 此外,我们也从增加可扩展性的方面进行了验证 ...
- 【SET】ORACLE SET 命令
set colsep' '; //-域输出分隔符 set echo off; //显示start启动的脚本中的每个sql命令,缺省为on set echo on ...
- HTTP协议——学习资料小结
嗯,这几天回头再次的学习Servlet的知识点,觉得HTTP协议的内容是相当重要的,现在虽然知道浏览器与应用程序的交互离不开它,但是怎么将信息从浏览器传输到服务器的这个知识点还是一个盲点.于是从网上找 ...