runoob js第十天

JavaScript JSON

JSON 是用于存储和传输数据的格式。
JSON 通常用于服务端向网页传递数据 。
什么是 JSON?

  • JSON 英文全称 JavaScript Object Notation
  • JSON 是一种轻量级的数据交换格式。
  • JSON是独立的语言 *
  • JSON 易于理解。
    *JSON 使用 JavaScript 语法,但是 JSON 格式仅仅是一个文本。
    文本可以被任何编程语言读取及作为数据格式传递。
    JSON 实例
    JSON 语法定义了 sites 对象: 3 条网站信息(对象)的数组
{"sites":[
    {"name":"Runoob", "url":"www.runoob.com"}, 
    {"name":"Google", "url":"www.google.com"},
    {"name":"Taobao", "url":"www.taobao.com"}
]}

JSON 格式化后为 JavaScript 对象
JSON 格式在语法上与创建 JavaScript 对象代码是相同的。
由于它们很相似,所以 JavaScript 程序可以很容易的将 JSON 数据转换为 JavaScript 对象。
JSON 语法规则

  • 数据为 键/值 对。
  • 数据由逗号分隔。
  • 大括号保存对象
  • 方括号保存数组
    JSON 数据 - 一个名称对应一个值
    JSON 数据格式为 键/值 对,就像 JavaScript 对象属性。
    键/值对包括字段名称(在双引号中),后面一个冒号,然后是值
"name":"Runoob"

JSON 对象
JSON 对象保存在大括号内。
就像在 JavaScript 中, 对象可以保存多个 键/值 对

{"name":"Runoob", "url":"www.runoob.com"}

JSON 数组
JSON 数组保存在中括号内。
就像在 JavaScript 中, 数组可以包含对象

"sites":[
    {"name":"Runoob", "url":"www.runoob.com"}, 
    {"name":"Google", "url":"www.google.com"},
    {"name":"Taobao", "url":"www.taobao.com"}
]
在以上实例中,对象 "sites" 是一个数组,包含了三个对象。
每个对象为站点的信息(网站名和网站地址)

JSON 字符串转换为 JavaScript 对象
通常我们从服务器中读取 JSON 数据,并在网页中显示数据。
简单起见,我们网页中直接设置 JSON 字符串

  1. 首先,创建 JavaScript 字符串,字符串为 JSON 格式的数据
var text = '{ "sites" : [' +
'{ "name":"Runoob" , "url":"www.runoob.com" },' +
'{ "name":"Google" , "url":"www.google.com" },' +
'{ "name":"Taobao" , "url":"www.taobao.com" } ]}';
  1. 然后,使用 JavaScript 内置函数 JSON.parse() 将字符串转换为 JavaScript 对象
var obj = JSON.parse(text);
  1. 最后,在你的页面中使用新的 JavaScript 对象
var text = '{ "sites" : [' +
    '{ "name":"Runoob" , "url":"www.runoob.com" },' +
    '{ "name":"Google" , "url":"www.google.com" },' +
    '{ "name":"Taobao" , "url":"www.taobao.com" } ]}';
obj = JSON.parse(text);
document.getElementById("demo").innerHTML = obj.sites[1].name + " " + obj.sites[1].url;

javascript:void(0) 含义

javascript:void(0) 中最关键的是 void 关键字, void 是 JavaScript 中非常重要的关键字,该操作符指定要计算一个表达式但是不返回值




下面的代码创建了一个超级链接,当用户点击以后不会发生任何事

单击此处什么也不会发生

当用户链接时,void(0) 计算为 0,但 Javascript 上没有任何效果。

以下实例中,在用户点击链接后显示警告信息





点我!

以下实例中参数 a 将返回 undefined




href="#"与href="javascript:void(0)"的区别
“#”包含了一个位置信息,默认的锚是#top 也就是网页的上端。
而javascript:void(0), 仅仅表示一个死链接。
在页面很长的时候会使用 # 来定位页面的具体位置,格式为:# + id。
如果你要定义一个死链接请使用 javascript:void(0) 。

点我没有反应的!
点我定位到指定位置!

...

尾部定位点

JavaScript 代码规范

代码规范通常包括以下几个方面:

  • 变量和函数的命名规则
  • 空格,缩进,注释的使用规则。
  • 其他常用规范……

规范的代码可以更易于阅读与维护。
代码规范一般在开发前规定,可以跟你的团队成员来协商设置。
变量名
变量名推荐使用驼峰法来命名(camelCase)

firstName = "John";
lastName = "Doe";

price = 19.90;
tax = 0.20;

fullPrice = price + (price * tax);

空格与运算符
通常运算符 ( = + - * / ) 前后需要添加空格

var x = y + z;
var values = ["Volvo", "Saab", "Fiat"];

代码缩进
使用 4 个空格符号来缩进代码块

function toCelsius(fahrenheit) {
    return (5 / 9) * (fahrenheit - 32);
}
不推荐使用 TAB 键来缩进,因为不同编辑器 TAB 键的解析不一样。

语句规则
简单语句的通用规则:

  • 一条语句通常以分号作为结束符。
var values = ["Volvo", "Saab", "Fiat"];
var person = {
    firstName: "John",
    lastName: "Doe",
    age: 50,
    eyeColor: "blue"
};

复杂语句的通用规则

  • 将左花括号放在第一行的结尾。
  • 左花括号前添加一空格。
  • 将右花括号独立放在一行。
  • 不要以分号结束一个复杂的声明。
函数:
function toCelsius(fahrenheit) {
    return (5 / 9) * (fahrenheit - 32);
}
循环:
for (i = 0; i < 5; i++) {
    x += i;
}
条件语句:
if (time < 20) {
    greeting = "Good day";
} else {
    greeting = "Good evening";
}

对象规则

  • 将左花括号与类名放在同一行。
  • 冒号与属性值间有个空格。
  • 字符串使用双引号,数字不需要。
  • 最后一个属性-值对后面不要添加逗号。
  • 将右花括号独立放在一行,并以分号作为结束符号。
var person = {
    firstName: "John",
    lastName: "Doe",
    age: 50,
    eyeColor: "blue"
};

短的对象代码可以直接写成一行:

var person = {firstName:"John", lastName:"Doe", age:50, eyeColor:"blue"};

每行代码字符小于 80

  • 为了便于阅读每行字符建议小于数 80 个
  • 超过了 80 个字符,建议在 运算符或者逗号后换行
document.getElementById("demo").innerHTML =
    "Hello Runoob.";

命名规则
一般很多代码语言的命名规则都是类似的,例如:

  • 变量和函数为小驼峰法标识, 即除第一个单词之外,其他单词首字母大写( lowerCamelCase)
  • 全局变量为大写 (UPPERCASE )
  • 常量 (如 PI) 为大写 (UPPERCASE )

变量命名你是否使用这几种规则: hyp-hens, camelCase, 或 under_scores ?

  1. HTML 和 CSS 的横杠(-)字符:
    HTML5 属性可以以 data- (如:data-quantity, data-price) 作为前缀。
    CSS 使用 - 来连接属性名 (font-size)。
    - 通常在 JavaScript 中被认为是减法,所以不允许使用。
  2. 下划线
    很多程序员比较喜欢使用下划线(如:date_of_birth), 特别是在 SQL 数据库中。
    PHP 语言通常都使用下划线。
  3. 帕斯卡拼写法(PascalCase)
    帕斯卡拼写法(PascalCase) 在 C 语言中语言较多
  4. 驼峰法
    JavaScript 中通常推荐使用驼峰法,jQuery 及其他 JavaScript 库都使用驼峰法
    变量名不要以 $ 作为开始标记,会与很多 JavaScript 库冲突
    HTML 载入外部 JavaScript 文件
    使用简洁的格式载入 JavaScript 文件 ( type 属性不是必须的)

                    
                    

你可能感兴趣的:(runoob js第十天)