什么是javascript?

javascript是一种直译型脚本语言,是一种动态类型、弱类型、基于原型的语言。(所谓“脚本语言”:指的是它不具有开发操作系统的能力,只是用来编写大型运用程序的脚本!)

javascript本身不提供任何与I/O(输入输出)相关的API,都是靠宿主环境提供!

常见的宿主环境:1.浏览器;  2.服务器,即Node项目。

宿主环境是浏览器,提供的额外API主要是三类:1.浏览器控制类(操作浏览器);2.DOM类(操作网页的元素);3.web类(实现互联网功能)

如果宿主环境是Node,提供的API:文件操作API;网络通信API等等。

javascript历史:

javascript与国际标准化组织ECMA(European Computer Manufaturers Association)的关系:

总结就是:ECMAScript是javascript的规格、标准;javascript是ECMA的实现!

ECMAScript只是用来标准化javascript这门语言的基本语法结构,与部署环境相关的标准是由其它标准规定,如DOM的标准由W3C制定!

ECMAScript的发布:

2009年12月,ECMAScript 5.0发布;

2011年6月,ECMAScript 5.1发布;

2015年6月,ECMAScript 6发布,并更名为“ECMAScript 2015”

更多有关javascript历史,可参考阮一峰教程

相关周边大事记:可参考

javascript变量:

 1+1;//没有意义,不报错
;;;//空语句,不报错
var a=1;//建议总是使用var 来申明变量!
b=1;//总是创建了全局变量
// console.log(a+" "+b);
console.log(a,b);
delete a;//delete无效
delete b;//删除成功
console.log(a);
console.log(b);//此时b被删除,报错

运行结果:

变量提升:

javascript引擎的工作原理:先解析代码,获取所有被申明的变量,然后再一行一行运行。

这样造成的结果是:所有变量的申明语句,都会被提升到代码的头部。这种原理叫变量提升(hoisting)

 //相当于var c; console.log(c); c=1;
console.log(c);
var c=1; console.log(d);
d=10;

运行结果:

undefined:表示变量c已经申明,但是未被赋值

d is not definded:表示变量d没有申明。(d不是var命令申明的,javascript引擎不会将其提升!)

注释:

单行注释://

多行注释:/* */

历史上,由于javascript兼容html代码注释,所以<!---->也被视为单行注释(个人不推荐这种写法!)

 <!-- 这里可以写注释内容
--> 这里可以写注释内容,注释符号必须在行首!否则会报错,或被当成运算符
var e=1;
if(e -->0){//相当于e-- >0
console.log(e);//输出0
}

区块:

使用大括号包括起来的语句,就是block(区块)。

注意:javascript区块不构成单独的作用域(scope)。即区块中的变量与区块外的变量,属于同一个作用域!(C++等语言出现这种情况会报错!)

 for(var i=0;i<5;i++){
console.log(i);
}
console.log(i);//输出5

switch:(使用严格相等运算符===比较!)

 var x=1;
switch (x) {
case true:
console.log('first step');
break;
case false:
console.log('second step');
default:
console.log('switch 中使用的是===严格相等运算符');
break;
}

运行结果:

 break和continue语句:(默认只针对一层循环!)(循环指的是while和for循环等)

break:跳出循环!

continue:立即终止本轮循环,返回循环结构头部,开始下一轮循环!

 var z=10;
while(z<=10){
z--;
if(z===9){
continue;//跳转到z--
}else{
console.log(z);
}
if(z===8){
console.log(z);
break;//跳转到while外面
}
}

标签:javascript语句前面可以有标签(label),相当于定位符,用于跳转到相应位置。

 abc://可随意起名,不需加引号
for(j=0;j<3;j++){
for(k=0;k<=j;k++){
if(k===j && k===1)
break abc;//跳出了这两层循环!
else
console.log(j+" "+k);
}
}

同理:continue后面也可加标签!满足条件时,跳过当前循环,进入下一轮外层循环;如果continue后面不加标签,则只能进入下一层内层循环

本文参考链接:阮一峰javascript标准参考教程

javascript(一):javascript基本介绍及基本语法的更多相关文章

  1. JavaScript (一) js的介绍及基本语法变量

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.JS 的 介绍 1.JavaScript :简称 : js js 分为三个部分: 1. ECMASc ...

  2. JavaScript function函数种类介绍

    JavaScript function函数种类介绍 本篇主要介绍普通函数.匿名函数.闭包函数 1.普通函数介绍 1.1 示例 ? 1 2 3 function ShowName(name) {     ...

  3. 教你如何在 Javascript 文件里使用 .Net MVC Razor 语法

    摘录 文章主要是介绍了通过一个第三方类库RazorJS,实现Javascript 文件里使用 .Net MVC Razor 语法,很巧妙,推荐给大家 相信大家都试过在一个 View 里嵌套使用 jav ...

  4. JavaScript压缩工具JSA使用介绍

    JavaScript压缩工具JSA使用介绍 JSA绝对是我使用过的JS压缩工具中最上乘的一个.认识它是从ligerUI开始.在ligerUI的QQ讨论组里,大神--ligerUI的作者告诉我他的lig ...

  5. JavaScript语言精髓(1)之语法概要拾遗(转)

    JavaScript语言精髓(1)之语法概要拾遗   逻辑运算 JavaScript中支持两种逻辑运算,“逻辑或(||)”和“逻辑与(&&)”,他们的使用方法与基本的布尔运算一致: v ...

  6. JavaScript中if语句优化和部分语法糖小技巧推荐

    前言 在前端日常开发过程中,if else判断语句使用的次数应该是比较频繁的了,一些较为复杂的场景,可能会用到很多判断,在某个代码块使用很多if else时,代码会显得较为冗余,阅读起来不够清晰. 除 ...

  7. 关于sass的介绍和基本语法

    引入 什么是sass?sass是css预处理器. 那预处理器又是什么?css本身不是一种编程语言,而预处理器是用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件. 如今主流的预处理器 ...

  8. 《编写可维护的JavaScript》——JavaScript编码规范(五)

    语句和表达式 在JavaScript中,诸如if和for之类的语句有两种写法,使用花括号的多行代码或者不使用花括号的单行代码.比如: //不好的写法,尽管这是合法的JavaScript代码 if (c ...

  9. JavaScript 对象JavaScript 对象

    JavaScript 中的所有事物都是对象:字符串.数值.数组.函数... 此外,JavaScript 允许自定义对象. 所有事物都是对象 JavaScript 提供多个内建对象,比如 String. ...

随机推荐

  1. Flink – metrics V1.2

    WebRuntimeMonitor   .GET("/jobs/:jobid/vertices/:vertexid/metrics", handler(new JobVertexM ...

  2. 20165317 Linux安装及学习

    Linux安装及学习 一.Linux的安装 我通过virtualbox和ubuntu官网下载了virtualbox5.2.6和ubuntu17.04版本. 在操作过程中,我基本是按照老师的步骤进行的, ...

  3. quartz定时任务cron表达式详解

    引用:https://www.cnblogs.com/lazyInsects/p/8075487.html cron表达式用于配置cronTrigger的实例.cron表达式实际上是由七个子表达式组成 ...

  4. SearchContextMissingException[No search context found for id [1545782]]

    这个原因是scroll的时间设置不够久,设久一些就可以了.

  5. 敏捷开发之Scrum扫盲篇(转)

    现在敏捷开发是越来越火了,人人都在谈敏捷,人人都在学习Scrum和XP... 为了不落后于他人,我也开始学习Scrum.今天主要是对我最近阅读的相关资料,根据自己的理解,用自己的语言来描述Scrum中 ...

  6. JVM java垃圾回收机制

    一.jvm简介 1.JVM内存运行时数据区的三个重要的地方 1.1.堆(heap):它是最大的一块区域,用于存放对象实例数组,是全局共享的. 1.2.栈(stack):全称为虚拟机栈,主要存储基本数据 ...

  7. 【Mock】mock基础、简单的单元测试代码练习。

    说到接口测试,必问 mock,mock 通俗一点来说就是模拟接口返回.解决接口的依赖关系,主要是为了解耦,单元测试用的多. 什么是Mock unittest.mock 是一个用于在 Python 中进 ...

  8. FreeMarker详解

    什么是 FreeMarker? FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具. 它不是面向最终用 ...

  9. what's the python之基本运算符及字符串、列表、元祖、集合、字典的内置方法

    计算机可以进行的运算有很多种,运算按种类可分为算数运算.比较运算.逻辑运算.赋值运算.成员运算.身份运算.字符串和列表的算数运算只能用+和*,字典没有顺序,所以不能进行算数运算和比较运算.比较运算中= ...

  10. Nginx中的rewrite指令(break,last,redirect,permanent)

    rewite 在server块下,会优先执行rewrite部分,然后才会去匹配location块 server中的rewrite break和last没什么区别,都会去匹配location,所以没必要 ...