JavaScript 和浏览器

模块

参见 ES6 部分

DOM

参见 Web 相关部分

选择器

  • document.querySelector() 来获取网页的对应 HTML 元素
  • document.querySelectorAll() 来获取网页的所有对应 HTML 元素
  • document.getElementById() 根据 ID 获取元素
  • document.getElementsByClassName() 根据类名获取元素
  • document.getElementsByTagName() 根据 HTML 元素名获取元素
document.querySelector('p');

事件处理

监听事件的函数叫“事件监听器(event listener)”;处理事件的函数叫“事件处理器(event handler)”。

常用的监听器:addEventListener(),第一个参数是事件的类型,第二个参数是事件处理器。

const target = document.querySelector('body');
function handleClick() {
  console.log('clicked the body');
}
target.addEventListener('click', handleClick);

也可以给 HTML 元素添加点击属性:

<h1 onClick='handleClick2()'></h1>
function handleClick2() {
  console.log('clicked the heading');
}

内容更新

可以使用 prompt() 内置方法获取用户输入。注:这不是最佳实践,应该使用表单。

let answer = prompt('What is your name?');
if (typeof(answer) === 'string') {
    var h1 = document.createElement('h1')
    h1.innerText = answer;
    document.body.innerText = '';
    document.body.appendChild(h1);
}
var h1 = document.createElement('h1')
h1.innerText = "Type into the input to make this text change"

var input = document.createElement('input')
input.setAttribute('type', 'text')

document.body.innerText = '';
document.body.appendChild(h1);
document.body.appendChild(input);

input.addEventListener('change', function() {
    h1.innerText = input.value
})

数据格式

XML

XML(Extensive Markup Language)扩展标记语言是早期常用的数据传输文件格式。

XML 需要很多字符来描述传输的数据,并且是一门独立语言,不容易和 JS 互操作。

JSON

2001 年,Douglas Crockford 发明了 JavaScript Object Notation / JSON。

JSON 的优势:

  1. 轻量级,语法类似 JS 的对象
  2. 容易用 JS 操作

除了作为数据传输格式外,JSON 还是一种文件格式,通常从第三方网站的 json 文件获取第三方数据。

规则

JSON 是一种格式化的字符串,以下规则是 JSON 数据或者从 JSON 中提取至 JS 对象中要遵守的:

  • 基本类型:字符串,数组,布尔,null
    • 字符串必须用双引号:"fruits"
    • 数字用常规 JS 语法表示:5,10,1.2
    • 布尔值用常规 JS 语法表示:true, false
    • null 必须是 null
  • 复杂类型:对象,数组(没有函数!)
  • 对象中所有键包含双引号
  • 在 JSON 对象中和 JSON 数组中,值是逗号分割的
  • 不能使用 JS 注释

如果尝试字符串化不受 JSON 支持的数据,例如函数,操作会“无声地”失败。

如果尝试字符串化其他数据类型,例如 BigInt:123n,会得到如下错误:Uncaught TypeError: Do not know how to serialize a BigInt.

一些合法的 JSON 实例:

'{  "color":"red",  "nestedObject": { "color": "blue" } }' 

'["one", "two", "three"]'

'[{ "color": "blue" }, {"color: "red"}]'

JSON -> Object

使用 parse() 从 JSON 提取至 JS 对象:

const jsonStr = '{"greeting": "hello"}'
JSON.parse(jsonStr); // {greeting: "hello"}

使用 JSON.stringify() 把对象转化为 JSON:

const data = {
  firstName: "John",
  lastName: "Doe",
  greeting: "Hello"
}

JSON.stringify(data) // '{"firstName": "John", "lastName": "Doe", "greeting": "Hello"}'
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • JavaScript 快速入门 浏览器浏览器对象操作 DOM插入 DOM删除 DOM 操作表单获取值设置值HTML...
    染微言阅读 1,625评论 0 5
  • Reference : JavaScript教程 - 廖雪峰的官方网站 浏览器 - 廖雪峰的官方网站 浏览器对象 ...
    shawn233阅读 397评论 0 0
  • BOM:浏览器对象模型,用来访问和操纵浏览器窗口,使用bom对象能获取浏览器信息、对当前浏览器窗口进行操控、文档对...
    小武__阅读 472评论 0 0
  • javaScript 浏览器事件 1.事件基本概念 事件是指文档或者浏览器中发生的一些特定交互瞬间,比如打开某一个...
    niklause_sun阅读 606评论 0 0
  • cookie cookie是客户端的会话跟踪技术(服务端为session) 作用: 将数据存储在浏览器中 生命周期...
    AuglyXu阅读 331评论 0 0