当前位置: 首页 > news >正文

外贸婚纱网站 侵权网站设计公司哪家便宜

外贸婚纱网站 侵权,网站设计公司哪家便宜,怎么做公司免费网站,如何自学网站建设​ js中判断了类型的方法有很多, 这篇文章主要来说一下常用的几种判断类型的方法,以及使用: 每个方法都各有优缺点,在日常使用的时候请结合这些优缺点进行斟酌: 1. 使用typeof判断数据类型 javaScript中typeof可以判断以下类型: undefined: 未定义的变量或者值 boolean: 布…​ js中判断了类型的方法有很多, 这篇文章主要来说一下常用的几种判断类型的方法,以及使用: 每个方法都各有优缺点,在日常使用的时候请结合这些优缺点进行斟酌: 1. 使用typeof判断数据类型 javaScript中typeof可以判断以下类型: undefined: 未定义的变量或者值 boolean: 布尔类型, true 或false number: 数值类型, 包括整数,浮点数, NaN, 和Infinity (无穷大) string: 字符串类星星, 表示文本 symbol:符号类型,ES6中新增的基本数据类型 function: 函数类型,可以作为一种特殊的对象类型 以下未测试代码以及输出内容: let num 213 console.log(type num, typeof num) // numberlet str 123 console.log(type str, typeof str) //stringlet nullValue null console.log(type nullValue, typeof nullValue) // objectlet undefinedValue undefined console.log(type undefinedValue, typeof undefinedValue)// undefinedlet obj {name:卡卡西,age:12} console.log(type obj, typeof obj) // objectlet boolValue true console.log(type boolValue, typeof boolValue) //booleanlet symbolValue Symbol(kk) console.log(type symbolValue, typeof symbolValue) //symbolfunction fun() {} console.log(type fun, typeof fun) //functionlet arr [1,2,3] console.log(typeof arr) // object需要注意的是null和arr这些也是typeof判断类型的局限性所在; typeof判断类型的局限性: typeof null的结果是object: 这是一个历史遗留问题, 在JavaScript最初的实现中将null的类型判断错误地设为object,因此使用typeof操作符判断null的时候得到的结果是object而不是nulltypeof数组|对象 返回的结果也是object: 虽然数组和对象在JavaScript中分别属于两种不同的数据类型,但是使用typeof判断他们的结果都是’object’ 无法区分他们的具体类型不能判断自定义对象类型:使用typeof操作符无法自定义对象的具体类型,因为所有的自定义对象都被视为一种object类型 需要注意的是,typeof能够快速判断出一些简单的类型的数据,但是对于复杂的数据类型判断会有一定的局限性,因此在实际编写代码时,需要结合其他的方法和技巧来判断数据类型 2. 使用instanceof判断类型 instanceof是javaScript中的一种运算符,用于判断某个对象是否属于某个类(或其父类)的实例,语法如下 object instance of constructor 测试代码如下: function Person(name) {this.name name; }let person1 new Person(卡卡西)console.log(person1 instanceof Person) // trueconsole.log(Person,Person) //[Function: Person]console.log(person1,person1) //Person { name: 卡卡西 }console.log(Person(),Person()) //undefinedclass A {} class B extends A {}let b new B() console.log(b instanceof B) // true console.log(b instanceof A) //trueclass Animal {} const dog {}; dog.constructor Animal; console.log(dog instanceof Animal); // false虽然instanceof运算符可以用来判断是否属于某个类的实例,但是他也存在一些局限性: 无法判断基本数据类型: instanceof 只能判断对象是否属于某个类的实例,不能判断基本数据类型,比如字符串,数字,如果要判断基本数据类型,需要使用其他方法construct 属性可能被篡改: instanceof 的判断依赖于对象的construct属性,如果对象的constructor属性被修改或篡改,那么instanceof就无法正确判断对象所属的类原型链较深时效率较低instanceof 的判断是基于原型链的当原型链较深时instanceof 的效率会较低因为它需要遍历整个原型链才能找到判断条件中的构造函数。 综上所述虽然 instanceof 运算符在某些情况下可以很方便地判断对象所属的类但是在实际开发中需要注意其局限性并结合其他方法和技巧来进行类型判断。 3. 使用Object.toString.call()判断数据类型 使用Object.toString.call()可以用来判断: 判断基本数据类型判断复杂数据类型判断null和undefined 需要注意的是Object.prototype.toString 方法返回的字符串格式为 “[object 数据类型]”其中数据类型和 JavaScript 中的数据类型名称一致。此外由于该方法是 Object 类型的原型方法因此需要通过 call 方法来调用确保 this 指向正确。 ​ const num2 0; console.log(object.toString.call(num2),Object.prototype.toString.call(num2))//[object Number]const str1 卡卡西 console.log(object.toString.call(str1),Object.prototype.toString.call(str1))// [object String]const obj2 {name:佐助,age:23} console.log(object.toString.call(obj2),Object.prototype.toString.call(obj2))//[object Object]const arr2 [1,2,3,4]; console.log(object.toString.call(arr2),Object.prototype.toString.call(arr2))//[object Array]const nullValue2 null console.log(object.toString.call(nullValue2),Object.prototype.toString.call(nullValue2))//[object Null]class Student {name;constructor(name) {this.name name;}}const student1 new Student(周周); console.log(object.toString.call(student1),Object.prototype.toString.call(student1))// [object Object]class Student2 {name;constructor(name) {this.name name;}toString(){console.log(this.name)}// 重写 Symbol.toStringTag 属性get [Symbol.toStringTag]() {return Student2;} }const student2 new Student2(周周) console.log(object.toString.call(student2),Object.prototype.toString.call(student2))// [object Student2]Object.prototype.toString.call()方法判断类型的局限性: 无法准确判断自定义类型: Object.prototype.toString.call 方法虽然可以准确地判断内置对象例如 Array、Object、Function 等和基本数据类型但无法准确地判断开发者自定义的类。如果想让他能判断自定义类型需要重写Symbol.toStringTag 属性不能区分继承关系: Object.prototype.toString.call 方法只能根据对象的原型链进行判断无法区分不同构造函数创建的相似对象的继承关系 4.不能跨域判断由于 JavaScript 中的安全机制当脚本执行跨域操作时Object.prototype.toString.call 方法也可能会返回错误的结果。这是因为部分浏览器实现了“沙箱”机制阻止了跨域脚本访问其他域名下的对象。
http://www.w-s-a.com/news/193066/

相关文章:

  • 江苏城乡与住房建设厅网站wordpress 添加导航
  • 免费单页网站在线制作网站制作与网站建设pdf
  • 网站开发使用云数据库技术教程大连模板开发建站
  • 佘山网站建设创造网站需要多少钱
  • 南海佛山网站建设网站维护需要什么技能
  • 阿里云服务器开源做几个网站想找公司做网站
  • 一般做网站是用什么语言开发的域名查询 查询网
  • 地方门户网站源码下载揭阳专业网站建设
  • 网站做优化好还是推广好wordpress百家号模版
  • 淘宝网网站建设的的意见校园微网站建设
  • 小说网站建设之前需求分析免费下载京东购物
  • 园林景观设计案例网站wordpress 文章内容页
  • 网站什么做才会更吸引客户楚雄网站开发rewlkj
  • 电商网站构建预算方案视频制作网站怎么做
  • 包装设计灵感网站ps软件下载电脑版多少钱
  • 手机网站图片做多大原网站开发新功能
  • 网站设计培训成都陕西网站建设公司哪有
  • expedia电子商务网站建设辽宁网站设计
  • 深圳网站建设网站运营绥芬河市建设局网站
  • 家政服务网站做推广有效果吗做图软件ps下载网站有哪些
  • 北京市建设教育协会网站flash网站制作单选框和复选框ui组件
  • 国外有没有做问卷调查的网站网站网页怎么做
  • 简单个人网站模板下载网站建设整体情况介绍
  • 网站建设做到哪些内容荆门网站建设电话咨询
  • 玉树网站建设公司双11主机 wordpress 2015
  • dw做网站背景图片设置汕头seo管理
  • 个人又什么办法做企业网站唐山哪里建轻轨和地铁
  • 手机网站404页面室内设计公司排名前100
  • 做民宿需要和多家网站合作吗创建软件的步骤
  • 网站导航栏设计要求辽宁省住房和城乡建设厅