位置: IT常识 - 正文

JavaScript详解(javascriptjs)

编辑:rootadmin
一、快速入门 1.JavaScript的两种引入方式 方式一:直接在html里面写 目的:实现简单的弹窗 点击查看代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <!--sc ... 一、快速入门1.JavaScript的两种引入方式

推荐整理分享JavaScript详解(javascriptjs),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript definitive guide,javascript+,javascript !,javascript的理解,javascriptjs,javascript的理解,javascriptj,javascriptj,内容如对您有帮助,希望把文章链接给更多的朋友!

方式一:直接在html里面写目的:实现简单的弹窗

点击查看代码<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title> <!--script标签内,写JavaScript代码,可以放在head标签里,也可以放在body标签里--> <script> <!--弹窗,打开页面时弹出一个窗口,并显示有hello,world--> alert('hello,world'); </script></head><body></body></html>

运行结果图方式二:新建一个js文件,在HTML中连接该文件也可以实现,就像css一样和HTML分开注意script标签必须是成对出现,

2.基本语法点击查看代码<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title> <!--Javascript严格区分大小写--> <script> //单行与多行注释与Java中注释的方式一样 /*1.定义变量 变量类型 变量名 = 变量值;*/ var score =100;//这里不写分号也没事 var name = "twq";//这里不写var也没事,就算不写变量名都可以,是不感觉可以随心所欲了 if(score>60 && score <70){ alert('小子,你很危险呀'); }else if(score > 70 && score < 80){ alert('革命尚未成功,同学 仍需努力呀!!'); }else{ alert('不要骄傲哦!'); } </script></head><body></body></html>

调试方法参照下图:

3.数据类型(1)number

js不区分小数和整数,Number

点击查看代码123//整数123123.1//浮点数123.11.123e3//科学计数法-99//负数NaN//not a numberInfinity//表示无限大

界面在浏览器上运行结果图

(2)字符串

和Java的一样

(3)布尔值

(4)逻辑运算

① && 两个都为真,结果为真② | | 一个为真,结果为真③ !真即假,假即真

(5)比较运算符

① = 赋值② == 等于(类型不一样,值一样,也会判断为true)③ === 绝对等于(类型一样,值一样结果为true)注意:这是Java的一个缺陷,坚决不要使用==比较须知:

NaN===NaN,这个与所有的数值都不相等,包括自己只能通过isNaN(NaN)来判断这个数据是否是NaN

(6)浮点数

尽量避免使用浮点数进行运算,存在精度问题!

(7)数组

java的数值必须是相同类型的对象,JS中需不要这样!如果数组下标越界会报undefined

(8)对象

对象是大括号,数组是中括号每个属性之间用逗号隔开,最后一个属性之后不需要逗号

点击查看代码<script> console.log((1/3)===(1-2/3)); console.log(Math.abs(1/3-(1-2/3))<0.00000001); //保证代码的可读性,尽量使用[] var arr=[1,2,3,4,5,'hello',null,true]; new Array(1,12,3,4,5,'hello'); var person ={ name:"Twq", age:23, tags:['js','java','web','...'] } </script>

运行结果图

4.严格检查模式点击查看代码<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title> <script> /*前提是IDEA需要设置支持ES6语法 *'use strict'严格检查模式,预防Javascript的随意性导致产生的一些问题如: * ①定义变量不写变量类型在没有写严格检查时不会报错,但是加上这严格检查之后就会报错 * 必须要写在JS的第一行 * 局部变量建议都使用let去定义 */ 'use strict'; /*let是块作用域,就会好比在for循环里用let定义了一个块变量 在循环的外部则无法使用该变量,var是函数作用域,在循环里面定义的 变量在循环外面也可以可以访问*/ let i = 1; </script></head><body></body></html>二、详解数据类型1.字符串(1)正常字符串,我们使用单引号或者双引号包裹(2)注意转义字符

①\'②\n③\u4e2d unicode字符格式:\u####④\41Ascll字符

(3)多行字符串编写

(4)模板字符串点击查看代码<script> //tab 上面 esc下面 let name = "Twq"; var msg =`你好呀,${name}`//在Java中连接两个字符串用加号,二JS可以使用$符号连接 </script>

运行结果图

(5)字符串长度

(6)字符串内容的不可变性

(7)大小写转换

(8)查找

(9)substringJavaScript详解(javascriptjs)

2.数组(1)长度

Array可以包含任意的数据类型注意:假如给arr.length赋值,数组大小就会发生变化,如果赋值过小,元素就会丢失

(2)indexOf,通过元素获得下标索引

在数组里字符串的1和数字1是不同的

(3)slice()

截取Array的一部分,返回一个新数组,类似于String中的substring

(4)尾部压入和弹出push(),pop()

从尾部压入和弹出元素

(5)unshift(),shift()

unshift()压入到头部shift()弹出头部的第一个元素

(6)sort()

(7)元素反转

(8)concat()

注意:concat()并没有修改原来的数组的值,只是会返回一个新的数组

(9)连接符join

打印拼接数组,使用特定的字符串连接

(10)多维数组

3.对象(1).使用一个不存在的对象属性,不会报错!undefined

(2)动态的删减属性

(3)动态的添加属性

(4)判断属性值是否在这个对象中

(5)判断一个属性是否是这个对象自身拥有的hasOwnProperty()

4.Map和Set(1)Map点击查看代码 <script> var map = new Map([['tom',100],['jack',900],['haha',80]]) console.log(map.get('jack')) map.set('admin',90);//新增或修改 map.delete('tom');//删除 for(let x of map){ console.log(x) } </script>

运行结果图

(2)Set

无序不重复的集合

点击查看代码 <script> var set = new Set([1,1,1,3]); set.add(2);//添加一个元素 set.delete(3);//删除一个元素 for(let x of set){ console.log(x) } console.log(set.has(1))//集合中是否包含1 </script>

运行结果图

四、函数1.定义函数(1)定义方式一点击查看代码<script> function abs(x){ if(x >= 0){ return x; } else{ return -x; } }</script>

运行结果一旦执行到return代表函数结束,返回结果如果没有执行return,函数执行完也会返回结果,结果就是undefined

(2)方式二:点击查看代码var abs = function(x){ if(x >= 0){ return x; } else{ return -x; } }

①参数问题:JS函数调用时可以传任意个参数,也可以不传参数都不会报错,如果想要报错可以手动定义一个异常

点击查看代码<script> var abs = function(x){ if(typeof x !== 'number'){//如果参数x的类型不是一个数 //手动定义异常 throw 'Not a number'; } if(x >= 0){ return x; } else{ return -x; } }</script>

运行结果②假设参入的参数有多个可以使用arguments关键词arguments:代表传递进来的所有参数,是一个数组

点击查看代码<script> var abs = function(x){ if(typeof x !== 'number'){//如果参数x的类型不是一个数 //手动定义异常 throw 'Not a number'; } for(let i =0; i<arguments.length;i++){ console.log(arguments[i]) } // if(x >= 0){ // return x; // } // else{ // return -x; // } }</script>

运行结果图③使用reset获取当前除已定义的参数以外的所有参数

点击查看代码<script> var abs = function(a,b,c,...rest){ console.log("a->"+a); console.log("b->"+b); console.log("c->"+c); console.log(rest); }</script>

运行结果

2.变量的作用域(1)在JavaScript中,var定义变量实际是有作用域的

假设在函数体中

本文链接地址:https://www.jiuchutong.com/zhishi/303208.html 转载请保留说明!

上一篇:帝国cms怎么安装(帝国cms怎么安装不了)

下一篇:web(website)

  • iphone13Safari浏览器怎么长截屏(iphonesafari浏览器)

    iphone13Safari浏览器怎么长截屏(iphonesafari浏览器)

  • 电脑版钉钉怎么联播(电脑版钉钉怎么取消自动登录)

    电脑版钉钉怎么联播(电脑版钉钉怎么取消自动登录)

  • 宽带200兆和300兆区别(宽带200兆和300兆在技术上有区别)

    宽带200兆和300兆区别(宽带200兆和300兆在技术上有区别)

  • 荣耀30青春版的快充是多少w的(荣耀30青春版的膜和别的型号通用)

    荣耀30青春版的快充是多少w的(荣耀30青春版的膜和别的型号通用)

  • 如何找爱奇艺下载的视频(爱奇艺下载怎么打开)

    如何找爱奇艺下载的视频(爱奇艺下载怎么打开)

  • 移动wlan什么意思(移动wlan什么意思要收费吗)

    移动wlan什么意思(移动wlan什么意思要收费吗)

  • gpu 适合处理哪些数据(gpu的性能)

    gpu 适合处理哪些数据(gpu的性能)

  • 苹果hdr是什么拍照功能(苹果hdr是什么拍摄)

    苹果hdr是什么拍照功能(苹果hdr是什么拍摄)

  • qq扩列老是匹配失败(qq扩列一直显示匹配失败2021)

    qq扩列老是匹配失败(qq扩列一直显示匹配失败2021)

  • qq里的隐身状态是什么意思(qq中隐身状态别人能看到吗)

    qq里的隐身状态是什么意思(qq中隐身状态别人能看到吗)

  • 苹果11截图快捷键(苹果11截图快捷没用怎么办)

    苹果11截图快捷键(苹果11截图快捷没用怎么办)

  • 多媒体创作系统大致可分为(多媒体创作系统包括)

    多媒体创作系统大致可分为(多媒体创作系统包括)

  • 蜂窝网络是什么意思(蜂窝网络是什么意思就是流量吗)

    蜂窝网络是什么意思(蜂窝网络是什么意思就是流量吗)

  • vivox27有nfc怎么开启(vivox21手机nfc)

    vivox27有nfc怎么开启(vivox21手机nfc)

  • 手机微信怎么发原图(手机微信怎么发送超过1个G的视频)

    手机微信怎么发原图(手机微信怎么发送超过1个G的视频)

  • 锐龙和酷睿的区别(锐龙跟酷睿的区别)

    锐龙和酷睿的区别(锐龙跟酷睿的区别)

  • 华为p20和p20lite区别(华为p20和p20pro区别)

    华为p20和p20lite区别(华为p20和p20pro区别)

  • 爱奇艺月卡激活码如何用(爱奇艺月卡激活卡密忘记了)

    爱奇艺月卡激活码如何用(爱奇艺月卡激活卡密忘记了)

  • vivoy3支持无线充电吗(vivo y3可以无线充电吗)

    vivoy3支持无线充电吗(vivo y3可以无线充电吗)

  • 快手pk怎么关闭(快手pk怎么关闭步骤)

    快手pk怎么关闭(快手pk怎么关闭步骤)

  • 抖音隐私设置什么意思(抖音隐私设置什么时间改为不见谁,可以见谁)

    抖音隐私设置什么意思(抖音隐私设置什么时间改为不见谁,可以见谁)

  • 同步接收别人手机短信(如何同步接收别人手机信息)

    同步接收别人手机短信(如何同步接收别人手机信息)

  • 华为sos紧急联络怎么设置(华为sos紧急联络怎么设置给110打电话)

    华为sos紧急联络怎么设置(华为sos紧急联络怎么设置给110打电话)

  • Python学习笔记(十一)-- Django API  RESTful(python初学笔记)

    Python学习笔记(十一)-- Django API RESTful(python初学笔记)

  • 解决ElementUI组件中el-upload上传图片不显示问题(elementui组件有哪些)

    解决ElementUI组件中el-upload上传图片不显示问题(elementui组件有哪些)

  • 软件退税收入会计分录
  • 残疾人保障金的工资按实发还是应发
  • 核定征收企业需要做账吗
  • 开办费抵扣多少企业所得税
  • 境外人员为境内企业提供劳务如何缴税
  • 哪些收入减免所得税
  • 期末账项调整的类型
  • 建设工程的停工损失包括哪些内容
  • 法院拍卖土地欠土地使用税
  • 房屋租赁协议填写版本
  • 企业自产自销的成本怎么核算?
  • 消费税价外费用的计算
  • 房地产开发公司取名
  • 收到汽车保险赔款怎么做账
  • 对方给我们开发票
  • 企业收到固定资产投资时应按什么入账
  • 合伙企业分红是免税企业需要缴纳什么税
  • 企业职工集资款的认定标准
  • 房屋出租收入是多少
  • cpu游戏性能天梯图2023
  • vscode国内镜像
  • 购买固定资产发生的支出是资本性支出
  • 腾讯电脑管家中的软件搬家
  • daio.dll 病毒
  • mac修改系统版本号
  • 交易性金融资产属于什么科目
  • 工会举办的比赛有哪些
  • 个体户要交哪些税怎么交
  • 转账支票购买办公用品会计
  • 解决本地浏览器的方法
  • 存货包括其他业务成本吗
  • AttributeError: ‘bytes‘ object has no attribute ‘encode‘异常解决方案
  • 小规模纳税人应纳增值税额的计算
  • gridviewcolumn
  • 增值税税收滞纳金哪里缴纳
  • php输出隔行变色的表格
  • input输入框非空验证
  • 应收账款账龄如何填写
  • 普通发票增量需要什么资料
  • 租赁合同印花税怎么申报缴纳
  • 备抵法账务处理方式
  • 织梦使用手册
  • 拍卖收入个人所得税
  • 其他综合收益影响所得税费用吗
  • 个人所得税汇算清缴
  • 已经经营中的企业有哪些
  • 农机合作社项目申报方案
  • 建筑行业怎样可以评高工
  • 产品检测费怎么入账
  • 投标费用如何入账科目
  • 从公司账户转给他人私户1万元以内需要扣多钱的税
  • 用于出租的设备属于什么资产
  • 出口转内销补交进口增值税时间
  • 企业注销在建工程怎么处理
  • 发票专用章盖在中间行不行
  • 收到红字发票进项税怎么做账务处理
  • 通过T_sql语句向其中一次填入一条数据或一次填入多条数据的方式填充数据
  • MySQL利用命令行工具启动和关闭的命令是什么
  • 查看mysql执行计划关键字
  • 计算机上没有运行windows无线服务
  • win10文字模糊怎么调整
  • winxp怎么装系统
  • vmware vnc连接
  • .ccc是什么文件
  • mfc100udll
  • c盘esd是什么文件夹
  • ubuntu 14.04安装
  • win10右键菜单管理在哪打开
  • Win10系统怎么添加字体
  • win10如何打开ie8
  • redhat linux yum
  • lrucache算法
  • texture packer工具
  • vlc录制没反应
  • Linux中的host命令应用实例详解
  • 在shell中获取脚本命令行参数的方法和区别
  • dom方法总结
  • jquery获取文件大小
  • 枸杞税收分类是什么
  • 车辆购置税怎么做账
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设