位置: 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)

  • 无法打开office open xml文件(无法打开)(无法打开office open xml文件 因为有错误)

    无法打开office open xml文件(无法打开)(无法打开office open xml文件 因为有错误)

  • airpods pro怎么注销原来的主人(airpods pro怎么注销)

    airpods pro怎么注销原来的主人(airpods pro怎么注销)

  • 手机QQ怎么开启厘米秀(手机QQ怎么开启青少年模式)

    手机QQ怎么开启厘米秀(手机QQ怎么开启青少年模式)

  • word没有输入法了怎么办(什么输入法好用)

    word没有输入法了怎么办(什么输入法好用)

  • 网卡工作在开放系统互联基本参osi中哪一层(网卡已启用 但是还是显示叉)

    网卡工作在开放系统互联基本参osi中哪一层(网卡已启用 但是还是显示叉)

  • 小米手环依据什么监测睡眠(小米手环依据什么生产的)

    小米手环依据什么监测睡眠(小米手环依据什么生产的)

  • 记忆棒和内存卡的区别(记忆棒和内存卡有关系吗)

    记忆棒和内存卡的区别(记忆棒和内存卡有关系吗)

  • 华为黑屏了怎么办打不开(华为黑屏了怎么导出数据)

    华为黑屏了怎么办打不开(华为黑屏了怎么导出数据)

  • 腾讯地图怎么设置3d实景导航(腾讯地图怎么设置起点)

    腾讯地图怎么设置3d实景导航(腾讯地图怎么设置起点)

  • iphone8跟iphone7区别(iphone7跟iphone8有什么区别)

    iphone8跟iphone7区别(iphone7跟iphone8有什么区别)

  • 小米手机fast boot什么意思(小米手机fastboot 无法开机)

    小米手机fast boot什么意思(小米手机fastboot 无法开机)

  • 探探看不到对方资料是被解除了吗(探探看不到对方动态相册)

    探探看不到对方资料是被解除了吗(探探看不到对方动态相册)

  • 100mbps是几兆(100mbps是几兆网速)

    100mbps是几兆(100mbps是几兆网速)

  • 手机页面显示hd是什么意思(手机页面显示hd2是什么意思)

    手机页面显示hd是什么意思(手机页面显示hd2是什么意思)

  • 跨境支付方式有哪些(跨境支付方式有哪些?)

    跨境支付方式有哪些(跨境支付方式有哪些?)

  • 为什么苹果发短信特效对方看不到(为什么苹果发短信发不出去)

    为什么苹果发短信特效对方看不到(为什么苹果发短信发不出去)

  • 苹果x能通话录音吗

    苹果x能通话录音吗

  • 黑鲨2支持无线充电吗(黑鲨支持无线充电功能吗)

    黑鲨2支持无线充电吗(黑鲨支持无线充电功能吗)

  • 天猫极速退款后卖家不肯退款成功(天猫极速退款后多久商家确认)

    天猫极速退款后卖家不肯退款成功(天猫极速退款后多久商家确认)

  • 腾讯视频怎么下线别的设备(腾讯视频怎么下载不了电视剧)

    腾讯视频怎么下线别的设备(腾讯视频怎么下载不了电视剧)

  • 拼多多怎么购买东西(拼多多怎么购买退货运费险)

    拼多多怎么购买东西(拼多多怎么购买退货运费险)

  • ios微信时间错乱(苹果手机微信时间错乱)

    ios微信时间错乱(苹果手机微信时间错乱)

  • 关于uni-app中uni-forms表单验证时“多级结构对象数据”如何做数据校验的解决方案(uni-app实例教程)

    关于uni-app中uni-forms表单验证时“多级结构对象数据”如何做数据校验的解决方案(uni-app实例教程)

  • import sklearn出现报错,如何正确安装sklearn(sklearn报错)

    import sklearn出现报错,如何正确安装sklearn(sklearn报错)

  • Vue显示图片的几种方式(vue图片放在哪里)

    Vue显示图片的几种方式(vue图片放在哪里)

  • 小规模纳税人减按1%政策文件
  • 待转销项税额是几级科目
  • 股东借款超过一年个人所得税
  • 聘用退休员工
  • 软件公司的销售
  • 房屋租赁需要交税吗?
  • 在建工程转固定资产凭证附件
  • 外汇结汇的方法有哪些呢?
  • 未认证的进项税账务处理
  • 城市维护建设税税率
  • 现金流量表本月数和本年累计数不一致
  • 公司管理层的作用
  • 土地增值税清算利息扣除规定
  • 个人所得税未缴算偷税吗
  • 通用机打发票能报销不
  • 法人可以公司账户存款吗
  • 预提差率费怎么记账
  • 拆迁补偿款需要交企业所得税吗
  • 出口转内销申报需要先做出口退税吗
  • 商铺水费收取标准2020
  • 计提代扣代缴个税
  • 新版edge浏览器如何恢复设置
  • 进项发票没认证可以开红字申请单吗
  • 以公司名义购买房产的利与弊
  • 土地使用权进项税如何抵扣
  • win11系统咋样
  • 低值易耗品现在还用吗
  • echarts引入地图
  • thinkphp ajaxfileupload实现异步上传图片的示例
  • 委托加工物资实际成本构成一般包括
  • 留抵税额进项构成比例
  • 移动加权平均法例题
  • 增值税发票可以作废重新开吗
  • nodejs安装及环境配置 centos
  • vmstat命令 监视系统资源状态
  • 房地产企业季度所得税预缴扣除附加税吗
  • 房地产企业建筑成本
  • 企业应采用
  • 固定资产的特点不包括
  • 配置windows update
  • 发票可以开未来日期吗
  • 分页 php
  • 新公司成立需要刻哪些章
  • 可供出售金融资产新准则叫什么
  • 酒店收入是什么收入
  • 销售自己使用过的固定资产
  • 管理费用的是
  • 小规模纳税人为什么不能抵扣进项税
  • 融资租入固定资产的租赁费属于什么费用
  • 电费应收和实收怎么算
  • 已经发出的商品替换零部件进成本还是费用
  • 税控盘反写是不是说明税都已经成功申报了
  • 公司成立前购买的固定资产
  • 为什么借贷平台借不到钱了
  • 建筑行业项目经理的岗位职责
  • 购置办公大楼,会计处理
  • 车子购买的保险
  • 预交了增值税款可以退吗
  • 出现亏损
  • 仲裁是什么意思举个例子
  • 工业企业建立账套
  • 非营利医疗机构是什么单位
  • 会计账簿按外表可分为
  • 自增字段必须是主键吗
  • 64位win8怎么安装南天PR2E针式打印机驱动?
  • centos7修改网络
  • 重装网卡驱动win11
  • win10系统的文件夹选项在哪里
  • win10系统中哪些软件可以删除
  • win7到欢迎界面卡半天
  • cocos2d原理
  • javascript中函数
  • jQuery的ajax中使用FormData实现页面无刷新上传功能
  • node.js中http模块和url模块的简单介绍
  • Linux 中常用的几种压缩工具?
  • JavaScript中String.match()方法的使用详解
  • unity3d赛车游戏毕业设计
  • 医院缴纳什么税
  • 年应税销售额超过小规模纳税人标准的企业
  • 南京市高新园区
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设