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

  • 发帖推广需要注意的哪些重要细节(发帖推广需要注意什么)

    发帖推广需要注意的哪些重要细节(发帖推广需要注意什么)

  • 华为手机设置怎么没有更多设置(华为手机设置怎么没有通用功能)

    华为手机设置怎么没有更多设置(华为手机设置怎么没有通用功能)

  • 电脑如何设置定时开关机(电脑如何设置定时播放音乐)

    电脑如何设置定时开关机(电脑如何设置定时播放音乐)

  • 优酷会员怎么看有效期(优酷会员怎么看成长值)

    优酷会员怎么看有效期(优酷会员怎么看成长值)

  • 抖音怎么看私信(抖音怎么看私信对方是否看过)

    抖音怎么看私信(抖音怎么看私信对方是否看过)

  • 苹果11电池健康99能恢复100吗(苹果11电池健康90)

    苹果11电池健康99能恢复100吗(苹果11电池健康90)

  • 华为手机一年保修包括什么(华为手机一年保修期内可以换屏吗)

    华为手机一年保修包括什么(华为手机一年保修期内可以换屏吗)

  • 电脑黑屏风扇狂转(电脑黑屏风扇狂转可以强制关机吗)

    电脑黑屏风扇狂转(电脑黑屏风扇狂转可以强制关机吗)

  • 手机定时闹钟怎么设置(手机定时闹钟怎么不响)

    手机定时闹钟怎么设置(手机定时闹钟怎么不响)

  • oppoa33为什么总显示空间不足(oppo手机为什么老)

    oppoa33为什么总显示空间不足(oppo手机为什么老)

  • 苹果4k和高清的区别(苹果4k好还是高清好)

    苹果4k和高清的区别(苹果4k好还是高清好)

  • 画图3d是什么软件(画图3d是什么软件做的)

    画图3d是什么软件(画图3d是什么软件做的)

  • 爱奇艺清晰度切换不了(爱奇艺建议切换清晰度)

    爱奇艺清晰度切换不了(爱奇艺建议切换清晰度)

  • 中文输入法的启动和关闭是用什么键(中文输入法的启动和关闭键是用什么键)

    中文输入法的启动和关闭是用什么键(中文输入法的启动和关闭键是用什么键)

  • 荣耀20青春版怎么添加拍照水印(荣耀20青春版怎么录屏)

    荣耀20青春版怎么添加拍照水印(荣耀20青春版怎么录屏)

  • 文档页面怎么变成一页(文档页面怎么变成竖的)

    文档页面怎么变成一页(文档页面怎么变成竖的)

  • 手机上位置信息的用途(如何查找手机位置信息)

    手机上位置信息的用途(如何查找手机位置信息)

  • 麦克风启用不成功(麦克风启用不成功怎么设置)

    麦克风启用不成功(麦克风启用不成功怎么设置)

  • 路由器中毒了如何处理(路由器中毒了如何解除)

    路由器中毒了如何处理(路由器中毒了如何解除)

  • 华为荣耀9x指纹识别在哪里(华为荣耀9x指纹设置不见了)

    华为荣耀9x指纹识别在哪里(华为荣耀9x指纹设置不见了)

  • 台式电脑怎么连无线网(台式电脑怎么连接手机热点共享网络)

    台式电脑怎么连无线网(台式电脑怎么连接手机热点共享网络)

  • 手机短信拦截在哪里设置(手机短信删除后怎么找回记录)

    手机短信拦截在哪里设置(手机短信删除后怎么找回记录)

  • 网页版b站怎么缓存(网页版b站怎么截图)

    网页版b站怎么缓存(网页版b站怎么截图)

  • excel未激活怎么处理(excel未激活可以用吗)

    excel未激活怎么处理(excel未激活可以用吗)

  • 简述对大数据的理解(简述对大数据的分析过程)

    简述对大数据的理解(简述对大数据的分析过程)

  • 麒麟Linux操作系统磁盘策略永久调整为deadline(麒麟软件的linux桌面操作系统)

    麒麟Linux操作系统磁盘策略永久调整为deadline(麒麟软件的linux桌面操作系统)

  • 防伪税控税务端官网
  • 销售服务增值税税率
  • 母公司和子公司可以一起投标吗
  • 开票地址一定要写全吗
  • 购车增值税可以抵扣多少
  • 安全生产费计提没用可以冲吗
  • 向银行办理托收手续记什么科目
  • 测绘费能否在土地出让
  • 未开票收入改为开票收入做账
  • 税务局代开的增值税专票可以红冲吗?
  • 未认证发票进项税分录
  • 产品成本的归集和分配是什么意思
  • 假的手撕票已经入账了怎么办?
  • 每月能领多少专利费
  • 税务清算审计需要多久
  • 有限合伙企业无限合伙企业
  • 税控盘锁死还能报税吗
  • 物流企业税务稽查要点
  • 发票认证勾选是一回事吗
  • 收入确认的
  • 出口加工区内企业可经营什么业务
  • lec风险评价方法
  • 代收代缴水电费能开发票吗
  • 资产评估入账的评估报告
  • 未开票的货款记什么科目
  • win10怎么接收手机热点
  • 滴滴代驾报酬
  • 施工企业内部往来核算方法包括( )
  • 苹果手机把旧手机的照片传到新手机
  • 如何在局域网内发布网页
  • php fopen ftp文件不存在
  • 支付给代理机构的手续费计入
  • 公司出租房屋租赁发票税率
  • php dechex
  • 最贵的电脑键盘
  • 享受所得税优惠情况说明
  • web前端框架是什么
  • jedis命令
  • 遍历目录文件
  • 中药饮片盘点误差范围
  • 微众银行贷款利率2023最新
  • 评价股权转让要交什么税
  • 加工费能直接抵税吗
  • java中反射
  • 内部交易费用外部交易费用
  • 税务局核定税种需要多久
  • 职业年金是不是养老保险
  • 私车公用费用报销
  • 维修设备增值税税率
  • 建筑劳务企业应发民工工资年终未发是否进行纳税调整
  • 客户手续费率
  • 财务费用明细账图片
  • 货款和发票金额一样吗
  • 固定资产清理账户的借方登记的项目有
  • 金蝶主要业务及软件产品
  • 出口货物退货需要交税吗
  • 股东股权转让会计分录
  • mysql常用查询
  • win7 64位系统插入磁盘提示“将磁盘插入驱动器”的解决方法
  • xp磁盘检测命令
  • 快速删除指定位置的结点用单链表还是双链表
  • 无人值守安装操作系统
  • linux calloc
  • linux配置java环境变量无法保存并退出
  • centos7误删除怎么恢复
  • linux系统的安装步骤
  • win7系统怎么禁止更新
  • android break
  • rsync安装使用详解
  • 修改windows server2012服务器密码
  • codeblocks使用技巧
  • css上下间距怎么设置
  • django自定义模板标签
  • 改变图片透明度怎么调
  • javascript 面向对象
  • java dom解析
  • 青岛税务局领导
  • 纳税人欠缴税款数额在10万元以上
  • 发票勾选后必须抵扣吗
  • 国税局官网查询平台
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设