JS快速上手-基础Javascript
1.1背景
1.1.1 ECMAScript与javascript
ECMAScript是javascript的官方命名。因为java已经是一个商标。如今,一些早前收到过授权的公司,如Moailla,是允许是有javascript这个名字的。使用javascript这个名字通常需要遵守一下规则:
~Javascript指的是一种编程语言。
~ECMAScript是这种语言规范的名字。so,每当提到这种语言的版本时,就是指ECMAScript.
1.1.2 javascript的影响和本质
javascript的创造者Brendan Eich.当时除了自己快速的创造这种语言外没别的选择(或者说,如果他不够快的话,Netscape公司将采用更糟糕的技术《Netscape/网景通信公司》)。
他借鉴了各种编程语言,如Java(语法、原始值和对象),Scheme、AWK(第一类函数),Self(原型继承)、Perl和Python(字符串、数组和正则表达式)。
直到ECMAScript 3之前,javascript都没有异常处理,这也是为什么他经常会自动转换值和静默失败的原因:他最初不能抛出异常。
一方面,javascript 有些怪异和功能缺失(比如块作用域、模块、子类支持等)。另一方面,他有许多强大的特性可以来弥补这些问题。在其他的语言里,我们学的是语言特性,而在jsvascript中,我们常学到的是模式。
有鉴于此,javascript支持函数式编程(高阶函数、内置的map 和 reduce等)和面向对象编程(对象、继承)的混合编程风格也就不足为奇了。
1.2 语法
1.2.1 语法概述
// two slashes start single-line comments 两条斜杠开始单行注释
var x; //declaring a value to the variable 'x' 声明一个变量
x = 3 + y; //assigning a value to the variable 'x' 将变量赋值给‘x’
foo(x,y); //calling function 'foo' with parameters 'x' and 'y' 调用带参x,y的函数
obj.bar(3); //calling method 'bar' of object 'obj' 调用方法“bar”的对象 'obj';
// A conditional statement 一个条件语句
if (x === 0){ //Is 'x' equal to zero? 'x'等于零吗?
x = 123;
}
“=”“==”和“===”的区别:http://www.cnblogs.com/liuqingxia/p/7792890.html
//Defining function 'baz' width parameters 'a' and 'b' 定义带参a,b函数‘baz’
function baz(a,b){
return a + b
}
1.2.2 语句和表达式
要理解javascript的语法,需要认识他的两大语法类别:语句和表达式。
~ 语句“做事情”。程序其实就是一系列的语句的集合。如这个语句的示例,他用来声明(或创建)一个变量 foo:
var foo;
~ 表达式产生值。他们通常是函数的参数,或是赋值的右边部分。比如:
3 * 7
js中有两种方式来实现 if - then - else,者可以很好的说明语句和表达式之间的区别。语句的方式:
var x;
if ( y > = 0){
x = y;
}else {
x = -y;
}
表达式的方式: var x = y >= 0? y : -y
后面这种方式可以用于函数的参数(前面的不行):
myFunction(y >= 0 ? y : -y)
1.3 变量和赋值
js里变量在声明后使用: var foo;
1.3.1 赋值
变量声明和赋值可以同时进行: var foo = 6;
也可以为一个已有变量赋值: foo = 4;
1.3.2 复合赋值运算符
在js中还会有复合赋值运算符,如 +=。以下两种赋值实际上是相等的:
x += 1;
x = x + 1;
复合赋值运算符详解:
1.3.3 标识符与保留字
标识符:
区分大小写,变量的名字都是标识符。Class与class就是不同的标识符。
标识符的首字符可以使下划线(_)、美元符($)、字母;
标识符除首字符外可以是下划线(_)、美元符($)、数字、字母。
例如:
_anh7、$ahn、asadas 合法的
1sds、class、room# 是不合法的
保留字:是语法的一部分,不能作为变量名使用(包括函数名和参数名):
arguments、break、case、catch、class、const、continue、debugger、default、delete、do、else、enum、export、extends、false、finally、for、function、if、implements、import、in、instanceof、interface、let、new、null、package、private、protected、public、return、static、super、switch、this、throw、true、try、typeof、var、void、while
以下3个标识符不是保留字,但同样需要视为保留字:
Infinity、NaN、undefined
JS快速上手-基础Javascript的更多相关文章
- 如何快速上手基础的CSS3动画
前言 说起CSS3动画,就必须说说 transform,translate,transition,animation这4个属性,transform主要定义元素的动作,比如旋转.倾斜.位移等,trans ...
- Three.js 快速上手以及在 React 中运用[转]
https://juejin.im/post/5ca22692f265da30a53d6656 github 的地址 欢迎 star! 之前项目中用到了 3D 模型演示的问题,整理了一下之前学习总结以 ...
- 异步编程:When.js快速上手
前些天我在团内做了一个关于AngularJS的分享.由于AngularJS大量使用Promise,所以我把基于Promise的异步编程也一并介绍了下.很多东西都是一带而过,这里再记录下. Angula ...
- Vue.JS快速上手(组件生命周期)
一.什么是组件 组成网页独立功能基本单元(片段), 复用.维护.性能, Vue.js中的组件就是一个Vue的实例,Vue中的组件包含data/methods/computed. 一个Vue.js的应用 ...
- Vue.JS快速上手(组件间的通信)
前言 Vue采用的是组件化思想,那么这些组件间是如何通信的呢?下面详细介绍一下. 所谓组件间通信,不单单是我们字面上理解的相互传递数据,这里还包括一个组件访问另一个组件的实例方法等,如父组件通过ref ...
- Vue.JS快速上手(指令和实例方法)
1.声明式渲染 首先,我们要知道Vue是声明式渲染,那啥是声明式渲染,我们只需要告诉程序我们想要什么结果,其他的交给程序来做.与声明式渲染相对的是命令式渲染,即命令我们的程序去做什么,程序就会跟着你的 ...
- Vue.JS快速上手(Vue-router 实现SPA 开发)
一.什么是路由 URL -> 映射 -> 组件 Hash+onhashchange History.pushstate+replaceState+onpopstate 二.准备工作 组件 ...
- React:快速上手(1)——基础知识
React:快速上手(1)——基础知识 React(有时叫React.js或ReactJS)是一个为数据提供渲染为HTML视图的开源JavaScript库,用于构建用户界面. JSX.元素及渲染 1. ...
- 【转】Vue.js 2.0 快速上手精华梳理
Vue.js 2.0 快速上手精华梳理 Sandy 发掘代码技巧:公众号:daimajiqiao 自从Vue2.0发布后,Vue就成了前端领域的热门话题,github也突破了三万的star,那么对于新 ...
随机推荐
- gulp的安装和使用
安装nodejs -> 全局安装gulp -> 项目安装gulp以及gulp插件 -> 配置gulpfile.js -> 运行任务 1.去nodejs官网安装nodejs 2. ...
- 思维水题:UVa512-Spreadsheet Tracking
Spreadsheet Tracking Data in spreadsheets are stored in cells, which are organized in rows (r) and c ...
- SMP IRQ Affinity
转:非常有用的方法,调式神器 SMP IRQ Affinity Background: Whenever a piece of hardware, such as disk controller or ...
- HDU 5047 Sawtooth 高精度
题意: 给出一个\(n(0 \leq n \leq 10^{12})\),问\(n\)个\(M\)形的折线最多可以把平面分成几部分. 分析: 很容易猜出来这种公式一定的关于\(n\)的一个二次多项式. ...
- configurationChanges
在Android中每次屏幕的切换动会重启Activity,所以应该在Activity销毁前保存当前活动的状态,在Activity再次Create的时候载入配置.在activity加上android:c ...
- Angularjs中的事件广播 —全面解析$broadcast,$emit,$on
Angularjs中不同作用域之间可以通过组合使用$broadcast,$emit,$on的事件广播机制来进行通信 介绍: $broadcast的作用是将事件从父级作用域传播至子级作用域,包括自己.格 ...
- 聊聊、Docker 安装
- xml和pandas结合处理的一个小例子-待完善
#!/usr/bin/env python3 # -*- coding:utf-8 -*- import pandas import json import xml.etree.ElementTree ...
- C# TypeDescriptor获取类型转换器,实现泛型转换
需求背景 平时的coding过程中,经常性遇到string类型转换成其他的基本类型,如 int double bool等,那我们正常的方式就是下面的方式进行类型转换 int.Parse("1 ...
- scikit-learn使用方法
1.支持向量机 #_*_ coding:utf-8 _*_ from sklearn import datasets from sklearn import svm #装载内部测试数据集 digits ...