1、block

一般就是{}包括起来的代码块,注意的是,js没有块作用域,但是有函数作用域,全局作用域。

2、var

1
var a = b = 1; 

如:

1
2
3
4
5
6
function () {
var a = b = 1;
}
foo();
console.log(typeof a); // "undefined"
console.log(typeof b); // "number" b为全局变量

3、try catch

1
2
3
4
5
6
7
try {
throw "test";
} catch(ex) {
console.log(ex); // "test"
} finally {
console.log("finally"); // finally
}

4、function

function fd() { // do something }; // 函数声明

var fe = function { // do something }; // 函数表达式

区别:函数声明可以在声明前调用,且无报错;而函数表达式不可以在声明前调用,有TypeError

5、for…in

1
2
3
4
5
var p;
var obj = {x:1, y:2};
for(p in obj) {
// 获取obj的key值
}

有几点需要注意:

  • 顺序不确定
  • enumerable为false时不显示
  • for…in 对象属性受到原型链的影响

6、严格模式

严格模式是一种特殊的执行模式,它修复了部分语言上的不足,提供更强的错误检查,并增强安全性

1
2
3
4
5
6
7
8
9
10
11
12
// 1.
function func() {
// ps:ie 不认该模式,会自动忽略严格模式
// 方法func按照严格模式执行
;
}大专栏  JavaScript之三 - 语法an> // 2.
"use strict" // 按照严格模式来
function func() { }

严格模式:

  • 不允许使用with(SyntaxError);
  • 不允许给未声明的变量赋值(RefrenceError);
  • arguments变为参数的静态变量;
1
2
3
4
5
6
7
8
9
10
11
// 正常状态下
!function(a) {
// "use strict";
arguments[0] = 100;
console.log(a);
}(1);
// ps: 若有传参的话,则arguments[0]可以改变a的值,即a的值为100,
// 若不传参,即!function(a){}();则无论是否有arguments的赋值,a都是为undefined
// 严格模式:
// 1) 值传递:传参则1,无传参则undefined
// 2) 址传递:若在无传参的情况下赋值则会报错
  • 严格模式下删除形参会报错(1.configurable为true则报SyntaxError;2.configurable为false则报TypeError);
  • 对象字面量属性重复报错。var obj = {x:1, x:2}; // SyntaxError
  • 禁止八进制字面量 console.log(0123); //SyntaxError
  • eval, arguments变为关键字,不能作为变量、函数名,若违反则报SyntaxError
  • eval独立作用域
1
2
3
4
5
6
7
8
9
10
!function() {
eval("val evalValue = 2;");
console.log(typeof evalValue);//number
}(); !function() {
;
eval("var evalValue = 2;");
console.log(typeof evalValue);//undefined,原因是eval独立作用域
}

严格模式总结:

  1. 不允许使用with;
  2. 所有变量必须声明,赋值给未声明的变量报错,而不是隐式创建全局变量;
  3. eval中的代码不能创建eval所在的作用域变量、函数,而是为eval单独创建一个单独的作用域,并在eval返回时废弃;
  4. 函数中的特殊对象arguments是静态副本,而不像非严格模式那样,修改arguments或修改形参会相互影响;
  5. 删除configurable为false会报错,而不是选择忽略;
  6. 禁止八进制字面量;
  7. eval、arguments为关键字,不能作为变量名或函数名;
  8. 一般函数的调用(不是对象方法的调用,也不是用apply/call/bind等修改this指向),this指向null而不是全局对象;
  9. 若使用apply/call,当传入null或者undefined时,this指向null或undefined而不是全局对象;
  10. 试图修改不可写属性(writable=false),在不可扩展的对象上添加属性时报TypeError,而不是忽略;
  11. arguments.caller、arguments.callee被禁用

JavaScript之三 - 语法的更多相关文章

  1. JavaScript基本语法(一)

    前段时间学习了HTML和CSS,也实战了一些结构较简单的项目.在还没运用到JS的知识时,做出来的效果总觉得少了些什么.虽然总体布局与一些基本的特效,也能用HTML+CSS就能完成.但如今开始进入Jav ...

  2. javascript运算符语法概述

    × 目录 [1]个数 [2]优先级 [3]结合性[4]类型[5]规则表 前面的话 javascript中的运算符大多由标点符号表示,少数由关键字表示,它们的语法言简意赅,它们的数量却着实不少.运算符始 ...

  3. javascript基础语法——表达式

    × 目录 [1]原始表达式 [2]复杂表达式 前面的话 一般地,关于javascript基础语法,人们听得比较多的术语是操作符和语句.但是,其实还有一个术语经常使用,却很少被提到,这就是javascr ...

  4. javascript基础语法——词法结构

    × 目录 [1]java [2]定义 [3]大小写[4]保留字[5]注释[6]空白[7]分号 前面的话 javascript是一门简单的语言,也是一门复杂的语言.说它简单,是因为学会使用它只需片刻功夫 ...

  5. JavaScript的语法规则

    JavaScript的语法规则 JavaScript区分大小写 JavaScript脚本程序须嵌入在HTML文件中 JavaScript脚本程序中不能包含HTML标记代码 每行写一条脚本语句 语句末尾 ...

  6. JavaScript的语法要点 1 - Lexically Scoped Language

    作为从一开始接触C.C++.C#的程序员而言,JavaScript的语法对我来说有些古怪,通过最近一年的接触,对它有了一定的了解,于是想把它的一些语法要点记录下来. 1. Block Scope vs ...

  7. javascript的语法作用域你真的懂了吗

    原文:javascript的语法作用域你真的懂了吗 有段时间没有更新了,思绪一下子有点转不过来.正应了一句古话“一天不读书,无人看得出:一周不读书,开始会爆粗:一月不读书,智商输给猪.”.再加上周五晚 ...

  8. 【repost】JavaScript 基本语法

    JavaScript 基本语法,JavaScript 引用类型, JavaScript 面向对象程序设计.函数表达式和异步编程 三篇笔记是对<JavaScript 高级程序设计>和 < ...

  9. JavaScript 中语法规范及调试

    JavaScript 中语法规范及调试 版权声明:未经博主授权,内容严禁分享转载 JavaScript 开发环境 JavaScript 脚本可以使用任意一款纯文本编辑器进行编程开发. 常见的前端开发编 ...

随机推荐

  1. 蓝桥杯 乘积最大(区间dp、数据水的话long long,暴力就能过)

    Description 今年是国际数学联盟确定的“2000——世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋 ...

  2. Java使用Thrift,Thrift结构体定义

    1.Thrift定义文件,Thrift常见的数据类型 1.基本类型(括号内为对应的Java类型): bool(boolean): 布尔类型(TRUE or FALSE) byte(byte): 8位带 ...

  3. RDD(五)——action

    reduce(func) 通过func函数聚集RDD中的所有元素并得到最终的结果,先聚合分区内数据,再聚合分区间数据.Func函数决定了聚合的方式. def main(args: Array[Stri ...

  4. 指定linux 下默认python版本

    sudo rm -rf python sudo ln -s /usr/bin/python3 /usr/bin/python

  5. mock简单的json返回

    针对非常简单的json返回串,我们也不一定非得通过freemarker模板的方式来构造返回数据,这里看实际的需求,如果返回的内容是固定的,而且json又非常简单,我们也可以直接写在程序里面,下面的接口 ...

  6. [CTS2019]氪金手游(容斥+树形背包DP)

    降智好题.本蒟蒻VP时没想到怎么做被题面迷惑了,只会20分的“好”成绩.简直自闭了. 首先显然度为0的点是白给的,根据等比数列求和公式即可求得.然后考虑这个树如果是一颗外向树,就是每个点先父亲再自己. ...

  7. Tomcat下访问HTML页面乱码的解决方法

    问题:在 Tomcat 服务器中访问 HTML 静态页面出现中文乱码,html 页面即使 charset 设置成 UTF-8 也会是乱码,打开浏览器的开发者工具发现 response 的请求头中的 C ...

  8. CString转换成std::string

    unicode的编码格式: CString strCS; std::string strSTD =  CT2A(strCS.GetBuffer()); 其他的编码格式: CString strCS; ...

  9. Office 365管理中心门户

    一.使用Office 365管理员账户登陆到由世纪互联运营的Office 365 登陆地址 https://portal.partner.microsoftonline.cn 1.登陆完成后,选择左上 ...

  10. 吴裕雄--天生自然python学习笔记:python文档操作表格处理

    表格也是 Word 文件中常用的对象,下面讲解 Win32com 中常用的表格操作命令 . 新建表格的语法为: 在 Word 文件中新建一个表格并插入单元格内容 在 Word 文件中新建一个 3 行 ...