这节博客主要讲解Dom模型概念~和JSON的简单介绍

首先,还是先上out.js的代码:

function println(param){
document.write(param+"<br/>");
} function print(param){
document.write(param);
}

什么是 DOM?

DOM 是 W3C(万维网联盟)的标准。

DOM 定义了访问 HTML 和 XML 文档的标准:

“W3C 文档对象模型 (DOM) 是中立于平台和语言的接口,它允许程序和脚本动态地访问和更新文档的内容、结构和样式。”

W3C DOM 标准被分为 3 个不同的部分:

核心 DOM - 针对任何结构化文档的标准模型

XML DOM - 针对 XML 文档的标准模型

HTML DOM - 针对 HTML 文档的标准模型

HTML DOM 定义了所有 HTML 元素的对象和属性,以及访问它们的方法。

换言之,HTML DOM 是关于如何获取、修改、添加或删除 HTML 元素的标准。

在这里,我们学的是HTML-DOM。

什么是 JSON ?

JSON 比 XML 更小、更快,更易解析。

JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)

JSON 是轻量级的文本数据交换格式

JSON 独立于语言 *,存储和交换文本信息的语法。类似 XML。

JSON 具有自我描述性,更易理解

* JSON 使用 Javascript语法来描述数据对象,但是 JSON 仍然独立于语言和平台。JSON 解析器和 JSON 库支持许多不同的编程语言。 目前非常多的动态(PHP,JSP,.NET)编程语言都支持JSON。

JSON - 转换为 JavaScript 对象

JSON 文本格式在语法上与创建 JavaScript 对象的代码相同。

由于这种相似性,无需解析器,JavaScript 程序能够使用内建的 eval() 函数,用 JSON 数据来生成原生的 JavaScript 对象。

  • JSON 使用 JavaScript 语法,但是 JSON 格式仅仅是一个文本。

    文本可以被任何编程语言读取及作为数据格式传递。

JSON 语法规则

数据为 键/值 对。

数据由逗号分隔。

大括号保存对象

方括号保存数组

演示代码:

<html>
<head>
<title>自定义对象--json的用法演示</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<script type="text/javascript" src="out.js">
</script>
<!-- 用js来描述我们自己的对象,如类似java当中的Person类 -->
<!-- 方式3 -->
<script type="text/javascript">
//json---在JavaScript中封装数据对象
//map
var pp = {
//"name":"张三","age":"23", //key:value
name: "张三",
age: "23",//这句和上面一句等效---key的名称可以省略引号
getName: function(){
//"getName":function(){//这句和上面一句等效
return this.name;
}
}; println(pp.name + "," + pp.age);
println(pp["name"] + "," + pp["age"]);//表示可以访问pp对象中的“name”和“age”属性
//注意这里属性是名称而不是变量,所以必须用引用 println(pp.getName());//调用函数
println(pp["getName"]);//显示出函数的代码
println(pp["getName"]());//调用函数
var map = {
8: "张三",
3: "李四",
5: "Jack"
};
println(map["8"]); //原理同前。json中冒号前面的那个是key,后面的是value
println(map[8]); //8是数字,不可能是变量名,因此引号省略照样能解析出来
</script>
<script type="text/javascript"> var myObj = {
name:"张三丰",age:23
};
println(myObj.name+","+myObj["age"]);//分别用了两种读取属性的方式
</script> <script type="text/javascript">
var myMap={
names:["Jack1","Jack2","Tom1","Tom2"],
nums:[10,20,30,40]
} println(myMap.names[1]+","+myMap.nums[1]); var myMap={
names:[{name:"Jack111"},{name:"Jack222"},{name:"Jack333"}]
} println(myMap.names[1].name);
println(myMap.names[1]["name"]);//与上面的访问一样的 </script> </body>
</html>

360浏览器8.1 演示结果:

Dom模型概念讲解

DOM: Document Object Model 文档对象模型

主要用来将标记型文档(html,xml)封装成对象,并将标记型文档中的所有内容(标签、文本、属性等)都封装成对象

既然都封装成了对象,那么就可以通过这些对象很方便地操作这些文档内容,达到操作页面内容–页面显示。

DOM树中的几个名词:

结点(节点):dom树中的标签、文本和属性等都称为结点(节点).

元素:dom树中的标签。

子节点 父节点(元素) 兄弟

父结点

主要用来将标记型文档(html,xml)封装成对象,并将标记型文档中的所有内容(标签、文本、属性等)都封装成对象

既然都封装成了对象,那么就可以通过这些对象很方便地操作这些文档内容,达到操作页面内容–页面显示。

DHTML技术:

动态的HTML —-html + css + dom +javascript 配合使用,来做动态html页面

HTML—负责提供标签,同时用标签封装数据

CSS—-负责显示样式

dom—-把整个页面中的标签、属性和文字内容封装成对象。

js—–提供程序设计语言,for,while,if

我们可以通过这个对象树来加深对DOM的了解。

(最下面部分未画出)对象树如下:

代码随便写写哒、

代码:

<html>
<head>
<title>湖南城院</title>
</head>
<body>
<div>div区域</div>
<dl>
<dt>上层项目</dt>
<dd>下层项目</dd>
</dl>
<table>
<tr> <th>姓名</th> </tr>
<tr> <td>张三</td> </tr>
</table>
<form>
<input type="text">
</form>
<a href="1.html">查看</a>
</body>
</html>

window对象中的对象

window 对象:

代表浏览器中一个打开的窗口。

navigator 对象

包含关于 Web 浏览器的信息。

属性— 描述

appCodeName— 获取浏览器的代码名称。

appMinorVersion— 获取应用程序的次版本值。

appName —获取浏览器的名称。

appVersion —获取浏览器运行的平台和版本。

browserLanguage —获取浏览器的当前语言。

cookieEnabled— 获取客户端的永久 cookie 是否在浏览器中启用。永久

cookies— 是储存在客户端计算机上的。

cpuClass— 获取指示 CPU 等级的字符串。

onLine —获取表明系统是否处于全局脱机模式的值。

platform —获取用户的操作系统名称。

systemLanguage— 获取操作系统适用的默认语言。

userAgent —获取等同于 HTTP 用户代理请求头的字符串。

userLanguage —获取操作系统的自然语言设置。

演示代码:

<html>
<head>
<title>Bom模型演示----window对象中的对象</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head> <body>
<!--
window中的所有对象在调用时,可以省略: window.
--> <script type="text/javascript" src="out.js">
</script> <script type="text/javascript">
function windowObjDemo(){
var name = window.navigator.appName;//获取浏览器的名称。
//var version = window.navigator.appVersion;
var version = navigator.appVersion;//获取浏览器运行的平台和版本。
println(name+"----"+version);
var pro = location.protocol; //设置或获取 URL 的协议部分。
println(pro);
var addr = location.href;//设置或获取整个 URL 为字符串。
println(addr);
}
function windowObjDemo2(){
//location.href ="http://www.baidu.com";//点击按钮,跳转到百度
location.href ="5a.html";
}
function windowObjDemo3(){
history.forward();//从历史列表中装入下一个 URL。//相对定位-相对的下一个-相当于浏览器中的前进按钮
}
</script>
<input type="button" value="演示window中的对象1" onclick="windowObjDemo()" />
<input type="button" value="演示window中的对象2" onclick="windowObjDemo2()" />
<input type="button" value="演示window中的对象3" onclick="windowObjDemo3()" />
</body>
</html>

5a.html:

<html>
<head>
<title>aa</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head> <body>
<script type="text/javascript">
function windowObjDemo(){
history.back();//从历史列表中装入前一个 URL。---相对定位,相对的前一个。-相当于浏览器中的后退按钮
}
</script>
<input type="button" value="演示window中的对象" onClick="windowObjDemo()" />
</body>
</html>

这里很简单,就不贴浏览器演示结果图片了。

JavaScript---网络编程(5)-自定义对象Json、Dom模型概念讲解的更多相关文章

  1. JavaScript---网络编程(6)-Dom和Bom模型概念讲解(节点获取,window对象)

    本节讲Dom和Bom模型概念讲解(节点获取,window对象). out.js: 写了2个输出到页面的函数. function println(param){ document.write(param ...

  2. JavaScript 创建和浅析自定义对象

    在Js中,除了Array.Date.Number等内置对象外,开发者可以通过Js代码创建自己的对象. 目录 1. 对象特性:描述对象的特性 2. 创建对象方式:对象直接量.new 构造函数.Objec ...

  3. javascript基础编程の变量、对象、数据类型及函数

    在web标准中.网页由结构.表现形式和行为三个部分组成. 结构标准---->XHTML: 表现形式标准----->CSS: 行为标准----->javascript: javascr ...

  4. c++ 网络编程(九)LINUX/windows-IOCP模型 多线程超详细教程及多线程实现服务端

    原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/9661012.html 先讲Linux下(windows下在后面可以直接跳到后面看): 一.线程 ...

  5. 网络编程中select模型和poll模型学习(linux)

    一.概述 并发的网络编程中不管是阻塞式IO还是非阻塞式IO,都不能很好的解决同时处理多个socket的问题.操作系统提供了复用IO模型:select和poll,帮助我们解决了这个问题.这两个函数都能够 ...

  6. 「JavaScript面向对象编程指南」对象

    对象的属性名可加上引号,下面三行代码所定义的内容是完全相同的 var hero = { occupation : 1 }; var hero = { "occupation" : ...

  7. iOS网络编程解析协议三:JSON数据传输解析

    作为一种轻量级的数据交换格式,正在逐步取代XML,成为网络数据的通用格式 基于JavaScript的一个子集 易读性略差,编码手写难度大,数据量小 JSON格式取代了XML给网络传输带来了很大的便利, ...

  8. 转载:Javascript面向对象编程原理 -- 理解对象

    源地址:http://www.html-js.com/article/1717 虽然JavaScript中已经自带了很多内建引用类型,你还是会很频繁的需要创建自己的对象.JavaScript编程的很大 ...

  9. JavaScript面向对象编程指南(四) 对象

    第4章 对象 4.1 从数组到对象 对象的组成:变量名.{}.用逗号分割的属性.用冒号分割的键/值对. var f={ name:'alen', // 可以在属性名上加引号 age:12 }; 对象文 ...

随机推荐

  1. apache虚拟主机安装注意事项

    apache虚拟主机在添加的时候,总是会有一些莫名其妙的问题,后来发现可以使用一个参数去验证的: xxxxx/httpd -S //这个参数会去检查虚拟主机配置的正确性,很好用 因为有时候可能就是缩进 ...

  2. PHP类中的__get()和__set函数到底有什么用?

    当试图获取一个不可达变量时,类会自动调用__get. 同样的,当试图设置一个不可达变量时,类会自动调用__set. 在网站中,这两个并不是什么非用不可的函数.   例如: Class Test {   ...

  3. think ajax 应用

    首先得引入 jquery 文件,另外定义一个处理的 js.js 文件 如实现用 post 传输方法: 模板文件: <script type="text/javascript" ...

  4. Java调用.Net WebService参数为空解决办法 (远程)调试webservice方法 转

    Java调用.Net WebService参数为空解决办法 (远程)调试webservice方法   同事遇到一个很囧的问题,java调,netwebservice的时候,调用无参数方法成功,调用有参 ...

  5. ruby环境sass编译中文出现Syntax error: Invalid GBK character错误解决方法

    sass文件编译时候使用ruby环境,无论是界面化的koala工具还是命令行模式的都无法通过,真是令人烦恼. 容易出现中文注释时候无法编译通过,或者出现乱码,找了几天的解决方法终于解决了. 这个问题的 ...

  6. centos下redis安装

    下载redis http://www.redis.cn/download.html 下载php的redis扩展 https://github.com/phpredis/phpredis#install ...

  7. python基础教程笔记—画幅好画(详解)

    今天写一下基础教程里面的第二个项目,主要使用python来做一个pdf的图,比较简单. 首先我们需要安装用到的模块pip install reportlab即可. 书上是用urlopen从往上下了一个 ...

  8. python学习_数据处理编程实例(二)

    在上一节python学习_数据处理编程实例(二)的基础上数据发生了变化,文件中除了学生的成绩外,新增了学生姓名和出生年月的信息,因此将要成变成:分别根据姓名输出每个学生的无重复的前三个最好成绩和出生年 ...

  9. We7在政府门户中的应用

    政府门户从传统的信息引导发展到现阶段的服务型门户,不论从角度转变上还是从平台选型上都跟以前有很大的不同,其更注重的是安全.扩展.易用和移动互联网几部分(当然这儿的注重是建立在已有政府门户电子政务三个板 ...

  10. Mvc学习笔记(4)

    上文我介绍了如何将控制器里的值传递给视图,但是是如何传递的呢?原理是什么? 视图 page.cshtml在编译的时候也会编译成一个类,然而这个类会继承于WebViewPage<object> ...