一、数据类型的转换

  1. 概述

    JavaScript是一种动态语言,变量没有类型限制,可以随时赋予任意值

  2. 强制转换:主要是值Number(),String(),Boolean三个函数

    Number函数,可以将任意类型的值转化为数值

    原始类型值的转换

    // 数值:转换后还是原来的值
    Number(324) // 324 // 字符串:如果可以被解析为数值,则转换为相应的数值
    Number('324') // 324 // 字符串:如果不可以被解析为数值,返回 NaN
    Number('324abc') // NaN // 空字符串转为0
    Number('') // 0 // 布尔值:true 转成 1,false 转成 0
    Number(true) // 1
    Number(false) // 0 // undefined:转成 NaN
    Number(undefined) // NaN // null:转成0
    Number(null) // 0

    对象的转换:Number方法的参数为对象时,返回NAN,除非是包含单个数值的数组

    Number({a: 1}) // NaN
    Number([1, 2, 3]) // NaN
    Number([5]) // 5 /*
    Number背后的转换规则
    第一步,调用对象自身的valueOf方法。如果返回原始类型的值,则直接对该值使用Number函数,不再进行后续步骤。 第二步,如果valueOf方法返回的还是对象,则改为调用对象自身的toString方法。如果toString方法返回原始类型的值,则对该值使用Number函数,不再进行后续步骤。 第三步,如果toString方法返回的是对象,就报错。
    */

    String函数可以将任意类型的值转换为字符串,转换规则如下

    原始类型的转化

    • 数值:转为相应的字符串。
    • 字符串:转换后还是原来的值。
    • 布尔值true转为字符串"true"false转为字符串"false"
    • undefined:转为字符串"undefined"
    • null:转为字符串"null"
    String(123) // "123"
    String('abc') // "abc"
    String(true) // "true"
    String(undefined) // "undefined"
    String(null) // "null"

    对象的转化:如果String参数是对象,返回一个类型的字符串,如果是数组,返回数组的字符串形式

    String({a: 1}) // "[object Object]"
    String([1, 2, 3]) // "1,2,3" /*
    String的转换规则
    先调用对象自身的toString方法。如果返回原始类型的值,则对该值使用String函数,不再进行以下步骤。 如果toString方法返回的是对象,再调用原对象的valueOf方法。如果valueOf方法返回原始类型的值,则对该值使用String函数,不再进行以下步骤。 如果valueOf方法返回的是对象,就报错。
    */

    Boolean函数可以将任意类型的值转为布尔值

    undefined,null,0,NAN,"" 转换为false,其他的值全是true.

    三种情况时,JavaScript会自动转换数据类型。

    1. 不同类型的数据互相运算

      123 + "abc";  //  123abc
    2. 对非布尔值类型的数据求布尔值

      if ('abc') {
      console.log('hello')
      } // "hello"
    3. 对非数值类型的值,使用+,-

      + {foo: 'bar'} // NaN
      - [1, 2, 3] // NaN

二、错误处理机制

  1. Error实例对象:JavaScript解析代码,一旦发送错误,就会抛出一个错误对象。

    var err = new Error("出错了");
    err.message; // 出错了
  2. 原生错误类型

    SyntaError对象:解析代码时发送的语法错误

    ReferenceError对象:引用一个不存在的变量时发生的错误

    RangeError对象:一个值超出有效返回时发送的错误

    TypeError对象:变量或者参数不是预期类型时发送的错误

    URLError对象:是URL相关函数的参数不正确时抛出的错误

    EvalError对象:eval函数没有被正确执行时,会抛出EvalError错误

  3. 自定义错误

    function UserError(message) {
    this.message = message || '默认信息';
    this.name = 'UserError';
    } UserError.prototype = new Error();
    UserError.prototype.constructor = UserError; new UserError("这是一个自定义错误")
  4. throw语句:手动中断程序执行,抛出一个错误

    if (x <= 0) {
    throw new Error('x 必须为正数');
    } // throw 它可以抛出任意类型,不单单只是Error对象
  5. try...catch结构:用于异常捕捉,防止程序报错,中断

    try {
    throw new Error("错误信息");
    } catch(error) {
    error.message;
    }

    为了捕捉不同类型的错误,catch代码块之中可以加入判断语句。

    try {
    foo.bar();
    } catch (e) {
    if (e instanceof EvalError) {
    console.log(e.name + ": " + e.message);
    } else if (e instanceof RangeError) {
    console.log(e.name + ": " + e.message);
    }
    // ...
    }
  6. finally代码块:不管程序是否出错,都会执行

JavaScript-语法专题的更多相关文章

  1. JavaScript:JavaScript语法的详细介绍

    JavaScript语法:只要Java会了,基本上javascript语法就会了. ——变量的定义 ——程序的结构控制 ——数组操作 ——函数的定义即使用 基本的test.html代码如下,它会导入下 ...

  2. javascript语法详解

    javascript语法:运算符 条件语句if...else...  条件语句switch  循环语句for  循环语句while   跳转语句 js运算符 1.算数运算符:+ - * % / ++ ...

  3. When Colon Scripting is comming(JavaScript语法扩充)

    当冒号脚本来临-- JavaScript语法扩充 连续好几夜的不能安眠,得出结论就是,未来语言未来的编译器应该是支持语法定制规则和语法扩展的,这样使得编程语言不断进化以更利于人类使用!of cours ...

  4. Javascript语法基础

    Javascript语法基础   一.基本数据类型   JavaScript中支持数字.字符串和布尔值三种基本数据类型: 1.数字 数字型是JavaScript中的基本数据类型.在JavaScript ...

  5. JavaScript语法细节——引用与复制

    原文:JavaScript语法细节--引用与复制 我们都知道,JS中变量的赋值有两种方式,最近在折腾自己写的标签栏插件,碰到了很多平时没注意的问题.正好,那边处理清楚了,稍微整理一下关于引用与复制相关 ...

  6. 第九十八节,JavaScript语法、关键保留字及变量

    JavaScript语法.关键保留字及变量 学习要点: 1.语法构成 2.关键字保留字 3.变量 任何语言的核心都必然会描述这门语言最基本的工作原理.而JavaScript的语言核心就是ECMAScr ...

  7. JavaScript 语法

    一.JavaScript简介 1.JavaScript是个什么东西? 它是个脚本语言,需要有宿主文件,它的宿主文件是HTML文件. 2.它与Java什么关系? 没有什么直接的联系,Java是Sun公司 ...

  8. JavaScript DOM 编程艺术(1)---> JavaScript语法

    一.  JavaScript语法目录 语法 操作 条件语句 循环语句 函数 对象 二.  具体内容 2.1 语法 javaScript代码要通过HTML/XHTML文档才能执行.可以有两种方式完成这一 ...

  9. JavaScript语法详解:JS简介&变量

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. JavaScript简介 Web前端有三层: HTML:从语义的角度,描 ...

  10. 读《javascript语法精粹》知识点总结

    昨天泡了大半天的读书馆,一口气看完了<javascript语法精粹>这本书,总体来说这本书还是写的不错,难怪那么多的推荐.<javascript语法精粹>主要是归纳与总结了ja ...

随机推荐

  1. Mysql只Union用法

    MYSQL中的UNION UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果. 举例说明: select * from table1 u ...

  2. 序列化json和protobuf大小比较

    使用protobuf序列化为二进制和json序列化字符串大小比较 代码demo package com.gxf.demo; import java.io.*; public class Ptotobu ...

  3. struts2的基本配置

    1.package标签下主要的点在namespace和name,extend上 extend 一般继承自struts-default.xml下,继承其拦截器及一些功能,这个已在本人的拦截器一文中有讲到 ...

  4. 【Android】4.0 神一样的仪式感:Android第一个项目HelloWorld——eclipse

    进入Eclipse,在左侧栏右击: 新建 “Android Application Project”项目,如果new之后没有,选择“Project”中“Android”目录下的 “Android Ap ...

  5. 测试css3的动画效果在display:none的时候不耗费性能

    也许你也有这个疑惑,动画一直在播放,那它不显示出来的时候也一直在播放的话,那是否一直占用资源呢? <!doctype html> <html> <head> < ...

  6. SpagoBI 和 开源ERP(iDempiere)整合入门

    Created by 蓝色布鲁斯,QQ32876341,blog http://www.cnblogs.com/zzyan/ iDempiere官方中文wiki主页 http://wiki.idemp ...

  7. wx.grid 简单例子

    import wx, wx.grid class GridData(wx.grid.PyGridTableBase): _cols = "a b c".split() _data ...

  8. Pairwise ranking methods: RankNet与LambdaRank

    转自:http://blog.csdn.net/u014374284/article/details/49385065, 感谢分享! LamdaMart 介绍见博客http://blog.csdn.n ...

  9. c++类模板成员函数报错

    类模板成员函数要不就在类模板中实现,要不就和类模板写在同一个文件中. 否则然会出现下面错误: >main.obj : error LNK2019: 无法解析的外部符号 "public: ...

  10. Android应用开发基础之三:数据存储和界面展现(三)

    生成XML文件备份短信 创建几个虚拟的短信对象,存在list中 备份数据通常都是备份至sd卡 使用StringBuffer拼接字符串 把整个xml文件所有节点append到sb对象里 sb.appen ...