博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js 入门 前端基础之JavaScript
阅读量:6839 次
发布时间:2019-06-26

本文共 7756 字,大约阅读时间需要 25 分钟。

hot3.png

一:引入文件两种方法:

1 Script标签内写代码

引入额外的JS文件

推荐使用第二种:

二: js注释:

JavaScript语言规范注释(注释是代码之母)

// 这是单行注释

/*这是多行注释*/

三:结束符 ;

四:js 语言基础:

变量声明

  1. JavaScript的变量名可以使用_,数字,字母,$组成,不能以数字开头。
  2. 声明变量使用 var 变量名; 的格式来进行声明
var name = "Alex";var age = 18;

注意:

变量名是区分大小写的。

推荐使用驼峰式命名规则。

保留字不能用做变量名。

 

 五:js 关键字:

163924_swbh_3648651.png

163937_fYh7_3648651.png

六:JavaScript数据类型

JavaScript拥有动态类型

var x;  // 此时x是undefinedvar x = 1;  // 此时x是数字var x = "Alex"  // 此时x是字符串

数字类型

JavaScript不区分整型和浮点型,就只有一种数字类型。

var a = 12.34;var b = 20;var c = 123e5;  // 12300000var d = 123e-5;  // 0.00123

还有一种NaN,表示不是一个数字(Not a Number)。

常用方法:

parseInt("123")  // 返回123parseInt("ABC")  // 返回NaN,NaN属性是代表非数字值的特殊值。该属性用于指示某个值不是数字。parseFloat("123.456")  // 返回123.456

字符串

var a = "Hello"var b = "world;var c = a + b; console.log(c);  // 得到Helloworld

常见字符串方法:

164044_P4WH_3648651.png

字符串拼接:

164112_uXDE_3648651.png

 

布尔类型

区别于Python,true和false都是小写。

var a = true;var b = false;

""(空字符串)、0、null、undefined、NaN都是false。

数组

类似于Python中的列表。

var a = [123, "ABC"];console.log(a[1]);  // 输出"ABC"

 

数组常用方法:

164207_xb6C_3648651.png

 

sort 排序要注意地方:

164308_ku3h_3648651.png

null和undefined

  • null表示值是空,一般在需要指定或清空一个变量时才会使用,如 name=null;
  • undefined表示当声明一个变量但未初始化时,该变量的默认值是undefined。还有就是函数无明确的返回值时,返回的也是undefined。

null表示变量的值是空,undefined则表示只声明了变量,但还没有赋值。

 

类型查询

typeof "abc"  // "string"typeof null  // "object"typeof true  // "boolean"typeof 123 // "number"

typeof是一个一元运算符(就像++,--,!,- 等一元运算符),不是一个函数,也不是一个语句。

 

对变量或值调用 typeof 运算符将返回下列值之一:

 

  • undefined - 如果变量是 Undefined 类型的
  • boolean - 如果变量是 Boolean 类型的
  • number - 如果变量是 Number 类型的
  • string - 如果变量是 String 类型的
  • object - 如果变量是一种引用类型或 Null 类型的

 

运算符

算数运算符

+ - * / % ++ --

比较运算符

> >= < <= != == === !==

注意:

1 == “1”  // true1 === "1"  // false

逻辑运算符

&& || !

赋值运算符

= += -= *= /=

 

 

七:流程控制

if-else

var a = 10;if (a > 5){  console.log("yes");}else {  console.log("no");}

if-else if-else 

 

var a = 10;if (a > 5){  console.log("a > 5");}else if (a < 5) {  console.log("a < 5");}else {  console.log("a = 5");}

 

switch

 

var day = new Date().getDay();switch (day) {  case 0:  console.log("Sunday");  break;  case 1:  console.log("Monday");  break;default:  console.log("...")}

 

switch中的case子句通常都会加break语句,否则程序会继续执行后续case中的语句。

 

for

for (var i=0;i<10;i++) {  console.log(i);}

while

var i = 0;while (i < 10) {  console.log(i);  i++;}

三元运算

var a = 1;var b = 2;var c = a > b ? a : b

 

 

八:函数

函数定义

JavaScript中的函数和Python中的非常类似,只是定义方式有点区别。

 

// 普通函数定义function f1() {  console.log("Hello world!");}// 带参数的函数function f2(a, b) {  console.log(arguments);  // 内置的arguments对象  console.log(arguments.length);  console.log(a, b);}// 带返回值的函数function sum(a, b){  return a + b;}sum(1, 2);  // 调用函数// 匿名函数方式var sum = function(a, b){  return a + b;}sum(1, 2);// 立即执行函数(function(a, b){  return a + b;})(1, 2);

 

arguments

function add(a,b){  console.log(a+b);  console.log(arguments.length)}add(1,2)

输出:

32

 

十:函数的全局变量和局部变量

局部变量

在JavaScript函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它(该变量的作用域是函数内部)。只要函数运行完毕,本地变量就会被删除。

全局变量:

在函数外声明的变量是全局变量,网页上的所有脚本和函数都能访问它。

变量生存周期:

JavaScript变量的生命期从它们被声明的时间开始。

局部变量会在函数运行以后被删除。

全局变量会在页面关闭后被删除。

作用域

首先在函数内部查找变量,找不到则到外层函数查找,逐步找到最外层。

几个例子:

1.

 

var city = "BeiJing";function f() {  var city = "ShangHai";  function inner(){    var city = "ShenZhen";    console.log(city);  }  inner();}f();  //输出结果是?

 

2.

 

var city = "BeiJing";function Bar() {  console.log(city);}function f() {  var city = "ShangHai";  return Bar;}var ret = f();ret();  // 打印结果是?

 

3.闭包

 

var city = "BeiJing";function f(){    var city = "ShangHai";    function inner(){        console.log(city);    }    return inner;}var ret = f();ret();

 

解析:

词法分析过程:1、分析参数,有一个参数,形成一个 AO.age=undefine;2、分析变量声明,有一个 var age, 发现 AO 上面已经有一个 AO.age,因此不做任何处理3、分析函数声明,有一个 function age(){...} 声明, 则把原有的 age 覆盖成 AO.age=function(){...};最终,AO上的属性只有一个age,并且值为一个函数声明执行过程:注意:执行过程中所有的值都是从AO对象上去寻找1、执行第一个 console.log(age) 时,此时的 AO.age 是一个函数,所以第一个输出的一个函数2、这句 var age=22; 是对 AO.age 的属性赋值, 此时AO.age=22 ,所以在第二个输出的是 23、同理第三个输出的还是22, 因为中间再没有改变age值的语句了

 

十一:内置对象和方法

JavaScript中的所有事物都是对象:字符串、数字、数组、日期,等等。在JavaScript中,对象是拥有属性和方法的数据。

我们在学习基本数据类型的时候已经带大家了解了,JavaScript中的Number对象、String对象、Array对象等。

注意var s1 = "abc"和var s2 = new String("abc")的区别:typeof s1 --> string而 typeof s2 --> Object

164725_rpjf_3648651.png

 

十二:自定义对象

类似于(某方面类似)Python中的字典数据类型

var a = {"name": "Alex", "age": 18};console.log(a.name);console.log(a["age"]);

遍历对象中的内容:

var a = {"name": "Alex", "age": 18};for (var i in a){  console.log(i, a[i]);}

创建对象:

var person=new Object();  // 创建一个person对象person.name="Alex";  // person对象的name属性person.age=18;  // person对象的age属性

 

扩展内容:

扩展:

 

// 父类构造函数var Car = function (loc) {  this.loc = loc;};// 父类方法Car.prototype.move = function () {  this.loc ++;};// 子类构造函数var Van = function (loc) {  Car.call(this, loc);};// 继承父类的方法Van.prototype = Object.create(Car.prototype);// 修复 constructorVan.prototype.constructor = Van;// 扩展方法Van.prototype.grab = function () {  /* ... */};

 

Date对象

创建Date对象

 

//方法1:不指定参数var d1 = new Date();console.log(d1.toLocaleString());//方法2:参数为日期字符串var d2 = new Date("2004/3/20 11:12");console.log(d2.toLocaleString());var d3 = new Date("04/03/20 11:12");console.log(d3.toLocaleString());//方法3:参数为毫秒数var d3 = new Date(5000);console.log(d3.toLocaleString());console.log(d3.toUTCString());//方法4:参数为年月日小时分钟秒毫秒var d4 = new Date(2004,2,20,11,12,0,300);console.log(d4.toLocaleString());  //毫秒并不直接显示

 

Date对象的方法:

 

var d = new Date(); //getDate()                 获取日//getDay ()                 获取星期//getMonth ()               获取月(0-11)//getFullYear ()            获取完整年份//getYear ()                获取年//getHours ()               获取小时//getMinutes ()             获取分钟//getSeconds ()             获取秒//getMilliseconds ()        获取毫秒//getTime ()                返回累计毫秒数(从1970/1/1午夜)

 

练习:

编写代码,将当前日期按“2017-12-27 11:11 星期三”格式输出。

详细Date对象方法:

JSON对象

var str1 = '{"name": "Alex", "age": 18}';var obj1 = {"name": "Alex", "age": 18};// JSON字符串转换成对象var obj = JSON.parse(str1); // 对象转换成JSON字符串var str = JSON.stringify(obj1);

 

 

RegExp对象

 

 

//RegExp对象//创建正则对象方式1// 参数1 正则表达式(不能有空格)// 参数2 匹配模式:常用g(全局匹配;找到所有匹配,而不是在第一个匹配后停止)和i(忽略大小写)// 用户名只能是英文字母、数字和_,并且首字母必须是英文字母。长度最短不能少于6位 最长不能超过12位。// 创建RegExp对象方式(逗号后面不要加空格)var reg1 = new RegExp("^[a-zA-Z][a-zA-Z0-9_]{5,11}$");// 匹配响应的字符串var s1 = "bc123";//RegExp对象的test方法,测试一个字符串是否符合对应的正则规则,返回值是true或false。reg1.test(s1);  // true// 创建方式2// /填写正则表达式/匹配模式(逗号后面不要加空格)var reg2 = /^[a-zA-Z][a-zA-Z0-9_]{5,11}$/;reg2.test(s1);  // true// String对象与正则结合的4个方法var s2 = "hello world";s2.match(/o/g);         // ["o", "o"]             查找字符串中 符合正则 的内容s2.search(/h/g);        // 0                      查找字符串中符合正则表达式的内容位置s2.split(/o/g);         // ["hell", " w", "rld"]  按照正则表达式对字符串进行切割s2.replace(/o/g, "s");  // "hells wsrld"          对字符串按照正则进行替换// 关于匹配模式:g和i的简单示例var s1 = "name:Alex age:18";s1.replace(/a/, "哈哈哈");      // "n哈哈哈me:Alex age:18"s1.replace(/a/g, "哈哈哈");     // "n哈哈哈me:Alex 哈哈哈ge:18"      全局匹配s1.replace(/a/gi, "哈哈哈");    // "n哈哈哈me:哈哈哈lex 哈哈哈ge:18"  不区分大小写// 注意事项1:// 如果regExpObject带有全局标志g,test()函数不是从字符串的开头开始查找,而是从属性regExpObject.lastIndex所指定的索引处开始查找。// 该属性值默认为0,所以第一次仍然是从字符串的开头查找。// 当找到一个匹配时,test()函数会将regExpObject.lastIndex的值改为字符串中本次匹配内容的最后一个字符的下一个索引位置。// 当再次执行test()函数时,将会从该索引位置处开始查找,从而找到下一个匹配。// 因此,当我们使用test()函数执行了一次匹配之后,如果想要重新使用test()函数从头开始查找,则需要手动将regExpObject.lastIndex的值重置为 0。// 如果test()函数再也找不到可以匹配的文本时,该函数会自动把regExpObject.lastIndex属性重置为 0。var reg3 = /foo/g;// 此时 regex.lastIndex=0reg3.test('foo'); // 返回true// 此时 regex.lastIndex=3reg3.test('xxxfoo'); // 还是返回true// 所以我们在使用test()方法校验一个字符串是否完全匹配时,一定要加上^和$符号。// 注意事项2(说出来你可能不信系列):// 当我们不加参数调用RegExpObj.test()方法时, 相当于执行RegExpObj.test("undefined"), 并且/undefined/.test()默认返回true。var reg4 = /^undefined$/;reg4.test(); // 返回truereg4.test(undefined); // 返回truereg4.test("undefined"); // 返回true

 

Math对象

 

 

abs(x)      返回数的绝对值。exp(x)      返回 e 的指数。floor(x)    对数进行下舍入。log(x)      返回数的自然对数(底为e)。max(x,y)    返回 x 和 y 中的最高值。min(x,y)    返回 x 和 y 中的最低值。pow(x,y)    返回 x 的 y 次幂。random()    返回 0 ~ 1 之间的随机数。round(x)    把数四舍五入为最接近的整数。sin(x)      返回数的正弦。sqrt(x)     返回数的平方根。tan(x)      返回角的正切。

 

 

转载于:https://my.oschina.net/u/3648651/blog/1796862

你可能感兴趣的文章
VC/MFC Tips
查看>>
加密和解密技术基础、PKI及创建私有CA
查看>>
Windows 注册和取消注册一个dll或者ocx
查看>>
vim对nginx的语法高亮设置
查看>>
ApiCloud云端管理平台(v.20151022)
查看>>
MVC3----筛选数据(BeginForm:输出form表单)
查看>>
我的友情链接
查看>>
基于Android平台的多分辨率解决方案[图]
查看>>
定向广播和本地广播
查看>>
ubuntu下安装nagios
查看>>
JVM致命错误日志(hs_err_pid.log)分析
查看>>
hdfs.DFSClient: Exception in createBlockOutputStre
查看>>
Android Context 上下文 你必须知道的一切
查看>>
我的友情链接
查看>>
UIScrollView无法滚动可能的原因及解决办法分析
查看>>
wince 6.0 串口 读取 readfile 超时问题
查看>>
代码片段
查看>>
单例模式
查看>>
awk用法(三)
查看>>
谷歌深度学习公开课任务 5: Word2Vec&CBOW
查看>>