JavaScript基础学习(一)

一、JavaScript概述

JavaScript的历史

  • 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件中).后将其改名ScriptEase.(客户端执行的语言)
  • Netscape(网景)接收Nombas的理念,(Brendan Eich)在其Netscape Navigator 2.0产品中开发出一套livescript的脚本语言.Sun和Netscape共同完成.后改名叫Javascript
  • 微软随后模仿在其IE3.0的产品中搭载了一个JavaScript的克隆版叫Jscript.
  • 为了统一三家,ECMA(欧洲计算机制造协会)定义了ECMA-262规范.国际标准化组织及国际电工委员会(ISO/IEC)也采纳 ECMAScript 作为标准(ISO/IEC-16262)。EcmaScript是规范.

ECMAScript

一个完整的 JavaScript 实现是由以下 3 个不同部分组成的:

  • 核心(ECMAScript)
  • 文档对象模型(DOM) Document object model (整合js,css,html)
  • 浏览器对象模型(BOM) Broswer object model(整合js和浏览器)
  • Javascript 在开发中绝大多数情况是基于对象的.也是面向对象的.

JavaScript的引入方式

  1. {#1 直接编写#}
  2. <script>
  3. alert('hello yuan')
  4. </script>
  5. {#2 导入文件#}
  6. <script src="hello.js"></script> 

二 JavaScript的基础

2.1 变量

1 声明变量时不用声明变量类型. 全都使用var关键字;

2 一行可以声明多个变量.并且可以是不同类型.

3 (了解) 声明变量时 可以不用var. 如果不用var 那么它是全局变量.

4 变量命名,首字符只能是字母,下划线,$美元符 三选一,且区分大小写,x与X是两个变量

5 变量还应遵守规则:

  1. 匈牙利类型标记法
  2. 在以 Pascal 标记法命名的变量前附加一个小写字母(或小写字母序列),说明该变量的类型。
  3. 例如,i 表示整数,s 表示字符串,如下所示“
  4. Var iMyTestValue = 0, sMySecondValue = "hi";

2.2 基础规范

1 每行结束可以不加分号. 没有分号会以换行符作为每行的结束

2 注释 支持多行注释和单行注释. /* */  //

使用{}来封装代码块

2.3 常量和标识符

标识符

2.4 数据类型

数字类型(Number)

整数:
           在JavaScript中10进制的整数由数字的序列组成
           精确表达的范围是
-9007199254740992 (-253) 到 9007199254740992 (253)
           超出范围的整数,精确度将受影响
浮点数:
           使用小数点记录数据
           使用指数记录数据

16进制和8进制数的表达
           16进制数据前面加上0x,八进制前面加0
           16进制数是由0-9,A-F等16个字符组成
           8进制数由0-7等8个数字组成
           16进制和8进制与2进制的换算

字符串(String)

是由Unicode字符、数字、标点符号组成的序列

布尔型(Boolean)

Boolean类型仅有两个值:true和false

Null & Undefined

  1. Undefined 类型
  2.  
  3. Undefined 类型只有一个值,即 undefined。当声明的变量未初始化时,该变量的默认值是 undefined
  4.  
  5. 当函数无明确返回值时,返回的也是值 "undefined";
  6.  
  7. Null 类型
  8.  
  9. 另一种只有一个值的类型是 Null,它只有一个专用值 null,即它的字面量。值 undefined 实际上是从值 null 派生来的,因此 ECMAScript 把它们定义为相等的。
  10.  
  11. 尽管这两个值相等,但它们的含义不同。undefined 是声明了变量但未对其初始化时赋予该变量的值,null 则用于表示尚未存在的对象(在讨论 typeof 运算符时,简单地介绍过这一点)。如果函数或方法要返回的是对象,那么找不到该对象时,返回的通常是 null
  12.  
  13. var person=new Person()
  14.  
  15. var person=null

数据类型转换

  1. 数字 + 字符串:数字转换为字符串
  2.  
  3. 数字 + 布尔值:true转换为1false转换为0
  4.  
  5. 字符串 + 布尔值:布尔值转换为字符串truefalse

强制类型转换函数

  1. 函数parseInt 强制转换成整数 例如parseInt("6.12")=6 ; parseInt(“12a")=12 ; parseInt(“a12")=NaN ;parseInt(“1a2")=1
  2.  
  3. 函数parseFloat: 强制转换成浮点数 parseFloat("6.12")=6.12
  4.  
  5. 函数eval: 将字符串强制转换为表达式并返回结果 eval("1+1")=2 ; eval("1<2")=true

类型查询函数(typeof)

  1. 例如typeof("test"+3) "string"
  2. 例如typeof(null) "object "
  3. 例如typeof(true+1) "number"
  4. 例如typeof(true-false) "number"

ECMAScript 运算符

ECMAScript 算数运算符

加(+)、 减(-)、 乘(*) 、除(/) 、余数(% ) 加、减、乘、除、余数和数学中的运算方法一样

i++相当于i=i+1,i--相当于i=i-1

一元加减法:

NaN:属于Number类型的一个特殊值,当遇到将字符串转成数字无效时,就会得到一个NaN数据

  1. var a=1;
  2. a=-a; //a=-1
  3.  
  4. var c="10";
  5. c=+c;
  6. alert(typeof (c)); //Number
  7.  
  8. var d="yuan";
  9. d=+d;
  10. alert(typeof(d)); //Number
  11.  
  12. //NaN特点:
  13.  
  14. var n=NaN;
  15.  
  16. alert(n>3);
  17. alert(n<3);
  18. alert(n==3);
  19. alert(n==NaN);
  20.  
  21. alert(n!=NaN);//NaN参与的所有的运算都是false,除了!=

ECMAScript 逻辑运算符

  1. 等于 ( == ) 、不等于( != ) 大于( > ) 小于( < )大于等于(>=) 、小于等于(<=)
  2. (&&) 、或(||) 、非(!)

如果某个运算数不是原始的 Boolean 型值,逻辑 AND 运算并不一定返回 Boolean 值:

  • 如果某个运算数是 null,返回 null。
  • 如果某个运算数是 NaN,返回 NaN。
  • 如果某个运算数是 undefined,返回undefined。
  1. JavaScript中=代表赋值,两个等号==表示判断是否相等
  1. 2 == 2 //true 做转化处理
  2. 2 === 2 //false 不做转化处理

ECMAScript等性运算符

  • 如果一个运算数是 Boolean 值,在检查相等性之前,把它转换成数字值。false 转换成 0,true 为 1。
  • 如果一个运算数是字符串,另一个是数字,在检查相等性之前,要尝试把字符串转换成数字。
  • 如果一个运算数是对象,另一个是字符串,在检查相等性之前,要尝试把对象转换成字符串。
  • 如果一个运算数是对象,另一个是数字,在检查相等性之前,要尝试把对象转换成数字。

ECMAScript 关系运算符(重要)

比较运算符两侧如果一个是数字类型,一个是其他类型,会将其类型转换成数字类型.

比较运算符两侧如果都是字符串类型,比较的是最高位的asc码,如果最高位相等,继续取第二位比较.
  1. var bResult = "Blue" < "alpha";
  2. alert(bResult); //输出 true 
  3.  
  4. var bResult = "25" < "3";
  5. alert(bResult); //输出 "true"
  6.  
  7. var bResult = "25" < 3;
  8. alert(bResult); //输出 "false"

Boolean运算符(重要)

  1. var temp=new Object();// false;[];0; null; undefined;object(new Object();)
  2.  
  3. if(temp){
  4. console.log("yuan")
  5. }else {
  6. console.log("alex")
  7. }

控制语句

if 控制语句

  1. if-else基本格式
  2. if (表达式){
  3. 语句1;
  4. ......
  5. }else{
  6. 语句2;
  7. .....
  8. }

switch  选择控制语句

  1. switch基本格式
  2. switch (表达式) {
  3. case 1:语句1;break;
  4. case 2:语句2;break;
  5. case 3:语句3;break;
  6. default:语句4;
  1. 在多路分支时用switchif..else if .. else结构要效率高。

for  循环控制语句

  1. for循环基本格式
  2. for (初始化;条件;增量){
  3. 语句1;
  4. ...
  5. }

while  循环控制语句

  1. while循环基本格式
  2. while (条件){
  3. 语句1
  4. ...
  5. }
  1. var i=1;
  2. while (i<=7) {
  3. document.write("<H"+i+">hello</H "+i+"> ");
  4. document.write("<br>");
  5. i++;
  6. }
  1. //循环输出H1到H7的字体大小
  1.  

异常处理

  1. try {
  2. //这段代码从上往下运行,其中任何一个语句抛出异常该代码块就结束运行
  3. }
  4. catch (e) {
  5. // 如果try代码块中抛出了异常,catch代码块中的代码就会被执行。
  6. //e是一个局部变量,用来指向Error对象或者其他抛出的对象
  7. }
  8. finally {
  9. //无论try中代码是否有异常抛出(甚至是try代码块中有return语句),finally代码块中始终会被执行。
  10. }

ECMA对象

var o = new Object();

object对象:ECMAScript 中的所有对象都由这个对象继承而来;Object 对象中的所有属性和方法都会出现在其他对象中

  1. ToString() : 返回对象的原始字符串表示。
  2. ValueOf() : 返回最适合该对象的原始值。对于许多对象,该方法返回的值都与ToString() 的返回值相同

11种内置对象

包括:

Array ,String , Date, Math, Boolean, Number  Function, Global, Error, RegExp , Object

Function 对象(重点)

  1. function 函数名 (参数){函数体;
  2. return 返回值;
  3. }
  1. function func1(){
  2. alert('hello yuan!');
  3. return 8
  4. }
  5.  
  6. var func1=new Function("name","alert(\"hello\"+name);")
  7.  
  8. // 匿名函数
  9. var func = function(arg){
  10. return "tony";
  11. }
  12.  
  13. // 匿名函数的应用
  14. (function(arg){
  15. console.log(arg);
  16. })('123')

运算符void()作用:拦截方法的返回值

  1. alert(void(fun1(1,2)))

ECMAScript 定义的属性 length 声明了函数期望的参数个数。

  1. alert(func1.length)

函数的调用

  1. function func1(a,b){
  2.  
  3. alert(a+b);
  4. }
  5.  
  6. func1(1,2); //3
  7. func1(1,2,3);//3
  8. func1(1); //NaN
  9. func1(); //NaN
  10.  
  11. //只要函数名写对即可,参数怎么填都不报错.
  12.  
  13. -------------------面试题-----------
  14. function a(a,b){
  15. alert(a+b);
  16. }
  17.  
  18. var a=1;
  19. var b=2;
  20. a(a,b)

函数的内置对象arguments

  1. function add(a,b){
  2.  
  3. console.log(a+b);//3
  4. console.log(arguments.length);//2
  5. console.log(arguments);//[1,2]
  6.  
  7. }
  8. add(1,2)
  9.  
  10. ------------------arguments的用处1 ------------------
  11. function nxAdd(){
  12. var result=0;
  13. for (var num in arguments){
  14. result+=arguments[num]
  15. }
  16. alert(result)
  17.  
  18. }
  19.  
  20. nxAdd(1,2,3,4,5)
  21.  
  22. // ------------------arguments的用处2 ------------------
  23.  
  24. function f(a,b,c){
  25. if (arguments.length!=3){
  26. throw new Error("function f called with "+arguments.length+" arguments,but it just need 3 arguments")
  27. }
  28. else {
  29. alert("success!")
  30. }
  31. }
  32.  
  33. f(1,2,3,4,5)

JavaScript 基础学习(一)的更多相关文章

  1. JavaScript 基础学习1-day14

    JavaScript 基础学习1 知识预览JavaScript概述二 JavaScript的基础三 JavaScript的对象BOM对象DOM对象实例练习js扩展 JavaScript概述 JavaS ...

  2. 48.javascript基础学习

    javascript基础学习:   http://www.w3school.com.cn/jsref/index.asp jS的引入方式: 1.行间事件:为某一个具体的元素标签赋予js内容,oncli ...

  3. JavaScript 基础学习(二)js 和 html 的结合方式

    第一种 使用一个标签 <script type="text/javascript"> js代码; </script> 第二种 使用 script 标签,引入 ...

  4. JavaScript 基础 学习 (四)

    JavaScript 基础 学习 (四) 解绑事件 dom级 事件解绑 ​ 元素.on事件类型 = null ​ 因为赋值的关系,所以给事件赋值为 null 的时候 ​ 事件触发的时候,就没有事件处理 ...

  5. JavaScript 基础 学习(三)

    JavaScript 基础 学习(三) 事件三要素 ​ 1.事件源: 绑定在谁身上的事件(和谁约定好) ​ 2.事件类型: 绑定一个什么事件 ​ 3.事件处理函数: 当行为发生的时候,要执行哪一个函数 ...

  6. JavaScript 基础 学习 (二)

    JavaScript 基础 学习 节点属性 ​ 每一个节点都有自己的特点 ​ 这个节点属性就记录着属于自己节点的特点 1. nodeType(以一个数字来表示这个节点类型) ​ 语法:节点.nodeT ...

  7. JavaScript 基础 学习 (一)

    JavaScript 基础 学习 获取页面中的元素的方法 作用:通过各种方式获取页面中的元素 ​ 比如:id,类名,标签名,选择器 的方式来获取元素 ​ 伪数组: ​ 长的和数组差不多,也是按照索引排 ...

  8. 几张非常有意义的JavaScript基础学习思维图

    分享几张对于学习JavaScript基础知识非常有意义的图,无论你的JavaScript级别如何,“温故而知新”完全可以从这些图中得到. 推荐理由:归类非常好,非常全面 JavaScript 数组 J ...

  9. HTML JavaScript 基础学习

    HTML 中肯定会用到 JavaScript 的知识点,会点 JavaScript 的基础知识不会吃亏,其实打算去买JavaScript的教程去专门学习一下,但是交给我的时间不多了,记录一点,能会一点 ...

  10. javascript基础学习--HTML DOM

    写在前面的话:由于学校没有开过javascript这门课,所以平时用javascript时都是用到什么就去搜什么样的代码,但是在工作中有时候搜来的代码总是有那么点小问题,而当自己想去修改时,却又无从下 ...

随机推荐

  1. Docker中使用Jenkins(3)

    一.前言 上一文章介绍了docker-compose,本文介绍Jenkins自动化部署. 二.Jenkins dockerfile文件切记右键属性复制到输出目录调整为:如果较新则复制,否则在publi ...

  2. 第一天 python环境变量安装(2.7)

    一.什么是python Python 是一个高层次的结合了解释性.编译性.互动性和面向对象的脚本语言. Python 的设计简单,易学,免费,开源,面向对象,可拓展性 Python 是一种解释型语言: ...

  3. SQL Server查看端口号及修改端口号

    使用下面的SQL Command就可以查看SQL SERVER的端口号 exec sys.sp_readerrorlog 0,1,'listening' 下图查询结果中端口号为1433 修改端口号步骤 ...

  4. 04_Linux完全卸载安装Mysql

    1.Linux环境完全卸载mysql相关文件: 完全卸载mysql相关文件:             yum remove mysql mysql-server mysql-libs compat-m ...

  5. Dependency Analyzer

    Dependency Analyzer  idea插件  查找maven依赖 1.Setting---->Plugins------>Dependency Analyzer 2.使用 po ...

  6. P1002 [NOIP2002 普及组] 过河卒

    P1002 [NOIP2002 普及组] 过河卒 题目见上. 一个经典的递推题 递推不会的看下面: https://www.cnblogs.com/haoningdeboke-2022/p/16247 ...

  7. Nacos安装与启动

    一.官网下载 1. 地址 https://github.com/alibaba/nacos/releases   二.安装 将下载的安装包解压至非中文目录即可,解压后目录: bin 目录下有启动脚本, ...

  8. 虚拟机中 Linux 提示“设备上没有空间”,扩容磁盘

    查看一下磁盘空间使用情况 #df -hl 已使用100% ls /dev/sd*  先查看一下现有sd系统硬盘 关机,存个快照(存不存无所谓),然后在虚拟机设置里添加扩展磁盘容量,选择SCSI类型 重 ...

  9. The table‘xxxx’is full

    df -h 查看磁盘 设置 back_log = 50 接受队列,对于没建立 tcp 连接的请求队列放入缓存中,队列大小为 back_log,受限制与 OS 参数,试图设定 back_log 高于你的 ...

  10. nuxt 服务端渲染注意事项

    1.路由 nuxt按照 pages 文件夹的目录结构自动生成路由 http://localhost:3000/user/reg 相当于 去访问 pages文件夹 下的 user文件夹 下的 reg.v ...