JavaScript -- 知识点回顾篇(一):数据类型,变量,类型转换,函数

1. 数据类型

  Boolean:值类型,布尔(逻辑)只能有两个值:true 或 false。

  Number:值类型,JavaScript 只有一种数字类型。数字可以带小数点,也可以不带

  string:值类型,字符串可以是引号中的任意文本。您可以使用单引号或双引号

  Undefined:只有一个值undefined

  Null:只有一个值Null

  Object:对象由花括号分隔。在括号内部,对象的属性以名称和值对的形式 (name : value) 来定义。属性由逗号分隔。

2. 声明变量

  (1)声明变量一般用 var 来声明(弱类型语言)。声明变量不写 var 关键字,表示该变量是一个整个页面都能访问的变量。

  (2)变量声明未赋值 -> undefined。

    <script type="text/javascript">
  var i;
  alert(i); //undefined
  </script>

  

  (3)变量未声明 -> 报错。

    <script type="text/javascript">
  alert(i);
  </script>

  

  (4)重复声明变量,忽略第二次声明,第二次的声明无效。(因为变量声明未赋值时,值是undefined。如果第二次声明有效,下图弹出的值应该是undefined)

    <script type="text/javascript">
  var i=10;
  var i;
  alert(i); //10
  </script>

   

3. 变量作用域

  在 js中不存在块级作用域范围。

  在方法内声明的变量,在整个方法内可用;在方法外部声明的变量,整个页面可用。

4. 数据类型转换

  (1)将字符串转换成数字类型:从第一个字符开始转,直到不能转换时返回。

      <script type="text/javascript">
var s='123adsja'
s=parseInt(s);
alert(s);
</script>

    

  (2)将数字当作 n 进制转换 (例:15作为8进制转换) 

      <script type="text/javascript">
var s=15
s=parseInt(s,8);
alert(s);
</script>

    

  (3)字符串转换成整数,转换成小数。直到不能转换时返回。

      <script type="text/javascript">
var s='32.666'
s=parseInt(s);
alert(s);
</script>

    

      <script type="text/javascript">
var s='32.6.4.2'
s=parseFloat(s);
alert(s);
</script>

    

  (4)把任意类型转换成数字类型

    Number(false)  ->  0

    Number(true)  ->  1

    Number(undefined)  ->  NaN

    Number('1.2')  ->  1.2

    Number('1.2.3')  ->  NaN

  (5)把任意类型转换成Boolean   ->  非空即为True

  (6)把任意类型转换成string

      <script type="text/javascript">
var s=123
alert(s.toString());
</script>

    

5. 判断一个值是否是一个 NaN ,不能用==,要用 isNaN

6. 逻辑运算符

  || :一个为真,不会再判断另一个

  &&:两个都要判断

7.  js 中没有函数重载,遇到同名函数,会用最后一次的函数定义覆盖前面的函数定义。

8. 在 js 中定义函数,无返回值类型,无参数类型(下图的函数 getSum 没有返回值类型,传入的参数a,b也没有变量类型)。

      <script type="text/javascript">
function getSum(a,b){
return a+b;
}
alert(getSum(10,20));
</script>

    

9. 函数

  (1)可变参数:实际调用时,所有的参数都包含在arguments对象中

    <script type="text/javascript">
function add(){
var sum=0;
for(var i=0;i<arguments.length;i++)
{
sum+=arguments[i];
}
return sum;
}
alert(add(10,30,20,20,20)); //100
</script>

    

  (2)在 js 中声明匿名函数   

    <script type="text/javascript">
var f = function (){
alert('Hello');
}
f();
</script>

    

  (3)函数的预解析:在一个<script></script>标签内,会把所有的函数先预解析,js 代码再从上到下执行。

10. js脚本执行

  当<script></script>块中的代码执行出错后,该块中的代码不会继续执行,但不会影响其他<script></script>块中的代码执行。

JavaScript -- 时光流逝(一):数据类型,变量,类型转换,函数的更多相关文章

  1. javascript 数据类型 变量 类型转换运算符

    数据类型: 1.字符串(被双引号所包含的内容),小数,整数,日期时间,布尔型等. 2.变量: 都是通用类型的var,    定义一个变量格式:var a: 3.类型转换: 分为自动转换和强制转换,一般 ...

  2. JavaScript -- 时光流逝(七):js中的全局函数

    JavaScript -- 知识点回顾篇(七):js中的全局函数 全局函数可用于所有内建的 JavaScript 对象. (1) encodeURI():把字符串编码为 URI. <script ...

  3. JavaScript学习笔记——2.数据类型与类型转换

    数据类型 JS中一共分成六种数据类型 1- String 字符串 2- Number 数值 3- Boolean 布尔值 4- Null 空值 5- Undefined 未定义 6- Object 对 ...

  4. JavaScript -- 时光流逝(九):Window 对象、Navigator 对象

    JavaScript -- 知识点回顾篇(九):Window 对象.Navigator 对象 1. Window 对象 1.1 Window 对象的属性 (1) closed: 返回窗口是否已被关闭. ...

  5. JavaScript -- 时光流逝(八):js中的事件Event的使用

    JavaScript -- 知识点回顾篇(八):js中的事件Event的使用 事件通常与函数配合使用,这样就可以通过发生的事件来驱动函数执行. (1) onabort : onabort 事件会在图像 ...

  6. JavaScript -- 时光流逝(十三):DOM -- Console 对象

    JavaScript -- 知识点回顾篇(十三):DOM -- Console 对象 (1) assert() : 如果断言为 false,则在信息到控制台输出错误信息.(2) clear() : 清 ...

  7. JavaScript -- 时光流逝(十二):DOM -- Element 对象

    JavaScript -- 知识点回顾篇(十二):DOM -- Element 对象 (1) element.accessKey: 设置或返回accesskey一个元素,使用 Alt + 指定快捷键 ...

  8. JavaScript -- 时光流逝(十一):DOM -- Document 对象

    JavaScript -- 知识点回顾篇(十一):DOM -- Document 对象 (1) document.activeElement: 返回文档中当前获得焦点的元素. <!doctype ...

  9. JavaScript -- 时光流逝(十):Screen 对象、History 对象、Location 对象

    JavaScript -- 知识点回顾篇(十):Screen 对象.History 对象.Location 对象 1. Screen 对象 1.1 Screen 对象的属性 (1) availHeig ...

随机推荐

  1. Perl和操作系统交互(二):fork

    fork + exec fork是低层次的系统调用,通过复制父进程来创建子进程. fork的行为 fork用来拷贝当前进程,生成一个基本完全一样的子进程. my $pid=fork(); 如果fork ...

  2. Spring Cloud Stream消费失败后的处理策略(一):自动重试

    之前写了几篇关于Spring Cloud Stream使用中的常见问题,比如: 如何处理消息重复消费 如何消费自己生产的消息 下面几天就集中来详细聊聊,当消息消费失败之后该如何处理的几种方式.不过不论 ...

  3. .NET CORE 实践(3)--Visual Studio 2015 Update 3更新之后DotNetCore.1.0.1-VS2015Tools.Preview2.0.2.exe无法正确安装

    打开 https://www.microsoft.com/net/core#windows,点击 https://go.microsoft.com/fwlink/?LinkId=691129下载vs2 ...

  4. [android] 在不同的activity之间传递数据

    新建一个activity,继承Activity 清单文件中进行配置,添加<activity/>节点 设置名称 android:name=”.类名” 点 代表的是当前包名,也可以不写 新建一 ...

  5. Java集合类根接口:Collection 和 Map

    前言 在前文中我们了解了几种常见的数据结构,这些数据结构有着各自的应用场景,并且被广泛的应用于编程语言中,其中,Java中的集合类就是基于这些数据结构为基础. Java的集合类是一些非常实用的工具类, ...

  6. SpringBoot登录登出切面开发

    阅读本文约“2.5分钟” 本文开发环境是SpringBoot2.X版本. 对于系统而言(这里多指管理系统或部分具备登录登出功能的系统),登录登出是一个类权限验证的过程,现在一般是以token进行校验, ...

  7. MySQL事务(学习笔记)

    MySQL事务主要用于处理操作量大,复杂度高的数据.比如说,在人员管理系统中,你删除一个人员,你即需要人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事 ...

  8. 2018年最值得关注的30个Vue开源项目

    译者按: 学习优秀的开源项目是提高代码水平最有效的方式. 原文: 30 Amazing Vue.js Open Source Projects for the Past Year (v.2018) 译 ...

  9. javascript对象与方法

    对象与方法 一.数组(Array) 1.使用new关键字创建数组 var box = new Array();                                     //创建了一个数 ...

  10. HTML 介绍及标签

    HTML htyper text markup language 即超文本标记语言 超文本: 就是指页面内可以包含图片.链接,甚至音乐.程序等非文字元素. 标记语言: 标记(标签)构成的语言. 标签 ...