JavaScript快速入门(二)——JavaScript变量
变量声明
JavaScript的变量声明分为显式声明跟隐式声明。
显式声明
即带var关键字声明,例如
var example = example;
要注意JavaScript里面声明的关键字只有function和var两个,不要和C之类的int、float等弄混了。
我们也可以暂时不初始化,和下面这句是等价的:
var example;
example = "example";
如果我们没初始化的话,变量将是undefined。但不建议不初始化,而是根据变量的用途来初始化,例如若变量为字符串,则赋值为空字符串,如果是数字,则赋值为0等等。
var variable1 = 1,
variable2 = 2,
variable3 = 3;
注意若是批量声明的话除了最后一个声明后面是分号其他的都是逗号,否则后面的变量会变成隐式声明变量。
用function关键字声明也属于显式声明,下面两句是等价的
function func() {}
var func = function() {}
隐式声明
example = "example";
这样也是合法的,那么两者有什么区别呢?
变量类型
前面说过JavaScript没有C的int、float等关键字,那么,JavaScript变量有没有类型呢?
废话,前面都说了,若变量为字符串,则初始化为空字符串等等,那就肯定有类型了。JavaScript共有6种基本变量
- 未定义 undefined
- 字符串 string
- 数值 number
- 布尔值 boolean
- 函数 function
- 对象 object
其中,前四种是值类型,后两种是引用类型,引用类型可以参照C里面的指针(但实际上JavaScript是没有指针的)
typeof(1234); // number
undefined类型
主要在以下情况出现
- 显式声明了但未初始化的变量
- 未声明直接引用的变量
- 直接初始化为undefined的变量
- 函数声明提升
后面的函数声明提升涉及JavaScript的解析原理,这里先不讲,以后有机会再讲
string类型
var str = "1234"; // str = "1234"
var str = new String(); // str = ""
var str = new String("1234"); // str = "1234"
如果String构造函数不传参数,则默认为空字符串。
var str = new String("1234");
console.log(str.length); // 4
"1234".length; // 4
所有对象(除undefined和null外)都有toString方法,传入String构造函数的任意类型数据都会被转换为字符串,包括undefined和null
var str = new String(1234); // str = "1234"
var str = new String(undefined); // str = "undefined"
var str = new String(null); // str = "null"
number类型
var num = 1234; // num = 1234
var num = new Number(undefined); // num = 1234
和字符串类似,如果我们传入构造函数的是其他类型的呢?
var num = parseInt("1234"); // num = 1234
如果被转化的对象里含有非数字字符,那么就会返回NaN(not a number),NaN表示应该返回number类型结果却没有
var num = parseInt("ab1234"); // num = NaN
boolean 类型
- number转Boolean:0为false,其他为true
- string转Boolean:空串为false,其他为true
- undefined转Boolean:永远为false
- object转Boolean:空对象为false,其他为true
- function转Boolean:永远为true
function类型
function func(param1, param2) {
return param1 + param2;
}
var func = function(param1, param2) {
return param1 + param2;
}
var func = new Function("param1", "param2", "return param1 + param2");
这三者在绝大多数情况下是等价的。之所以说绝大部分,是因为在函数声明提升中会有所不同,这里也不涉及。
object类型
var obj = new Object();
var obj = {};
object类型变量可以使用object方法,object类型有prototype属性(JavaScript继承的基础)
JavaScript快速入门(二)——JavaScript变量的更多相关文章
- JavaScript快速入门(四)——JavaScript函数
函数声明 之前说的三种函数声明中(参见JavaScript快速入门(二)——JavaScript变量),使用Function构造函数的声明方法比较少见,我们暂时不提.function func() { ...
- Web开发初探之JavaScript 快速入门
本文改编和学习自 A JavaScript Primer For Meteor 和 MDN Web教程 前文 Web开发初探 概述 本文以介绍 JavaScript 为主,初学者掌握本文的内容后,将能 ...
- JavaScript快速入门-ECMAScript基础语法
一.JavaScript引入方式 1.行内式 <script> alert(123); </script> 2.外链式 <script src='custom.js'&g ...
- JavaScript快速入门-ECMAScript函数
JavaScript函数(定义.参数.返回值.闭包.匿名函数) 一.函数定义 function functionName(arg0, arg1, ... argN) { statements } 函数 ...
- javascript快速入门2--变量,小学生数学与简单的交互
变量 对于变量的理解:变量是数据的代号.如同人的名字一样. var num;//在JavaScript中使用关键字var声明一个变量 在JavaScript中,使用上面的语法,就可以声明一个变量,以便 ...
- JavaScript快速入门(一)——JavaScript概览
JavaScript是什么? JavaScript的诞生 在1995年前后,当时世界上的主流带宽为28.8Kbps,现在世界平均下载带宽为21.9Mbps(数据来源于http://www.netind ...
- javascript快速入门1--JavaScript前世今生,HelloWorld与开发环境
JavaScript历史 大概在1992年,一家称作Nombas的公司开始开发一种叫做C--(C-minus-minus,简称Cmm)的嵌入式脚本语言. Cmm背后的理念很简单:一个足够强大可以替代宏 ...
- javascript快速入门22--Ajax简介
Ajax是什么? 首先,Ajax是什么?一个很酷的新兴词汇!仅仅是某种早就有了的技术的一种新说法而已! Ajax是指一种创建交互式网页应用的网页开发技术.要谈到网页应用程序,则必须从WEB的历史来讲: ...
- python3.5+django2.0快速入门(二)
昨天写了python3.5+django2.0快速入门(一)今天将讲解配置数据库,创建模型,还有admin的后台管理. 配置数据库 我们打开mysite/mysite/settings.py这个文件. ...
随机推荐
- JVM -- 类加载
学习自周志明老师的<深入理解Java虚拟机>第二版 类的加载时机 如上图所示: 类从被加载到虚拟机内存中开始,直到卸载出内存为止,它的整个生命周期包括了: 加载.验证.准备.解析.初始化. ...
- USACO Subset 整数划分01背包
又是去理解了一次01背包. 这道题目的意思就是给你一个N (N < 40)表示有一个集合{1,2,3,... n} 你要将它划分成相等的两个子集合,求有几种划分方式 如果N是奇数,那么显然不能由 ...
- U+00A0 (Non-breaking space)无法被正确压缩
Code Glyph Decimal HTML Description #U+00A0 Non-breaking space 0096 https://zh.wikipedia.org/wik ...
- Android 系统稳定性 - ANR(一)
文章都为原创,转载请注明出处,未经允许而盗用者追究法律责任.很久之前写的了,留着有点浪费,共享之.编写者:李文栋 如果你是一个Android应用程序开发人员,你的人生中不可避免的三件事情是:死亡.缴 ...
- Hadoop伪分布式模式部署
Hadoop的安装有三种执行模式: 单机模式(Local (Standalone) Mode):Hadoop的默认模式,0配置.Hadoop执行在一个Java进程中.使用本地文件系统.不使用HDFS, ...
- 一天一个类,一点也不累 之 LinkedList
我们的口号是,一天一个类,一点也不累 .. 今天要讲的是---LinkedList 首先,还是看看他的组织结构 Class LinkedList<E> java.lang.Object j ...
- 知识普及:iOS7搭载新定位技术iBeacon
摘自:http://iphone.91.com/tutorial/jcjc/131023/21619035.html 在2013年六月举行的WWDC上,作为iOS 7中最重要的新特性之一,苹果正式对外 ...
- 知识点1-4:ASP.NET MVC的好处
ASP.NET MVC解决了ASP.NET Web Form的许多缺点.当在.NET平台上开发新的应用程序时,这使ASP.NET MVC成为一种更好的选择. 1. 对HTML的完全控制 2. 对URL ...
- docker学习笔记5:利用commit命令创建镜像 和 删除本地镜像
一.概述 创建镜像有两种方法,一是用commit命令,二是用dockerfile方法(这个更常用,在下面文章介绍).本章介绍commit方法. 在介绍commit命令前,我们先回顾下对代码的版本控制, ...
- switch的方便用法
int ch = getch(); switch(ch) { case '0' ... '9': if (in_count) { count = count * 10 + (ch - '0'); } ...