第61节:Java中的DOM和Javascript技术

Java中的DOMJavascript技术

DOM是一门技术,是文档对象模型.所需的文档只有标记型文档,如我们所学的html文档(文档中的所有标签都封装成为对象了)

DOM: 为Document Object Model, 文档对象模型, 是用来将标记文档以及文档中的标签等所有内容都封装成对象.

把标签文档中所有的标签封装成对象, 文档也封装成对象,DOM技术(标记型文档封装成对象)

DOM技术存在浏览器中,内置了DOM技术解析器,变对象是需要进行解析的,描述进行封装.在内存当中进行解析,为Demo.html文档.

内存中把文档进行解析,文档封装成对象.

这些对象都会在内存中产生.在内存中进行解析,我们看到这种树结构,每个部分我们都称为节点,进行解析就对象.DOM的技术,使得文档和内容都变成了对象,才有了操作的这些对象的属性和行为.

DHTML:
动态的html,实现了与用户的动态交互,多项技术综合的简称.(HTML,CSS,JAVASCRIPT,DOM + xmlHTTPRequest为AJAX)

HTML:提供标签,用于封装数据.
css:提供样式.
JavaScript:提供逻辑型较强的程序设计,可以用来对对象进行操作和控制,是负责页面的动态效果和行为.
DOM:提供解析,将标记文档以及文档中的内容都封装成为对象,这样就可以操作对象中的属性和行为.

BOM模型

Browser Object Model 浏览器对象模型,浏览器本身就是一个对象.将浏览器以及浏览器中的内容封装成对象.

window: 本身代表浏览器窗体对象.

window对象

<input type="button" value="按钮" onclick="alert('hello')"/>
<input type="button" value="按钮" onclick="locationDemo()"/>
<script type="text/javascript">
 function locationDemo(){
  alert('hello');
 }
</script>

window对象:

对象 描述
location 包含关于当前URL的信息
navigator 包含关于web浏览器的信息
screen 包含关于客户屏幕和渲染能力的信息
event 代表事件状态,如事件发生的元素,键盘状态,鼠标位置和鼠标按钮状态
document 代表给定浏览器窗口中的html文档

location对象: 包含关于当前URL的信息.

属性 描述
host 设置或获取location或url的hostname和port号码
hostname 设置或获取location或url的hostname和port号码
href 设置或获取整个url为字符串
pathname 设置或获取对象指定的文件名或路径
方法 描述
assign 装入新的Html文档
reload 重新装入当前页面
replace 装入指定url的另外文档来替换当前文档
<script type="text/javascript">
 function locationDemo(){
  alert(location.href);
 }
</script>

getElementById 根据‘id‘ 标签属性指定值的第一个对象的引用
getElementsByName 根据name标签属性的值获取对象的集合
getElementsByTagName 根据获取指定元素名称的对象集合.

<body>
<script text="text/javascript">
 function document(){
  var divNode = document.getElementById("divid");
  alert(divNode.nodeName);
  alert(divNode.innerHTML);
  divNode.innerHTML = "达叔".fontcolor("red");
 }
</script>
<input type="button" value="document对象" onclick="documentDemo()"/>
<div>区域</div>
<table>
<tr>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</table>
<span></span>
<input type="text" name="user"/>
<a href="https://www.jianshu.com/u/c785ece603d1">达叔小生</a>
</body>

getElementsByName

<input type="text" name="user"/>
<script text="text/javascript">
function documentDemo(){
 var nodes = documents.getElementsByName("user");
 alert(nodes[0].value);
}
</script>

getElementsByTagName

id属性,name属性,表单标签中经常具有name属性.

function documentDemo(){
 var divNodes = document.getElementsByTagName("div");
 // 遍历节点
 for(var x=0; x<divNodes.length; x++){
  alert(divNodes[x].innerHTML);
 }

 var tableNode = document.getElementById("tableid");
 var divNodes2 = tableNode.getElementsByTagName("div");
 for(var y=0; y<divNodes2.length; y++){
  alert(divNodes2[y].innerHTML);
 }
}

层次关系获取节点

  1. 父节点唯一性
  2. 子节点不唯一性,是数组
function getNodeByDemo(){
 var tableNode = document.getElementById("tableid");
 var node = tableNode.parentNode;
 alert(node.nodeName);
 var nodes = tableNode.childNodes;
 alert(nodes.length);
 alert(nodes[0].nodeName);
 // 节点的子节点
 var nodes = tableNode.childNodes[0].childNodes;
 for(var z=0; z<nodes.length; z++){
  alert(nodes[z].nodeName);
 }
 // 获取兄弟节点
 var node=tableNode.nextSibling;
 alert(node.nodeName);
 var node2 = tableNode.perviousSibling;
 alert(node2.nodeName);
}

案例

javascript:void(0)是用来取消默认效果的, 超链接本身带有默认的事件,现在该超链接不需要默认的事件处理.就需要进行消除.

处理方式,需要进行明确的处理节点,获取该节点的对象,并调用其属性和行为.

<div id="newsdiv">
 <h1>标题</h1>
 <a href="javascript:void(0) onclick="changeFont(24px)"  ">大字体</a>
 <a href="javascript:void(0) onclick="changeFont(16px)" ">中字体</a>
 <a href="javascript:void(0) onclick="changeFont(10px)" ">小字体</a>
 <hr>
 <div id="newstext">
达叔小生
 </div>
</div>

// div文字的大小
<div id="newsdiv">
 <h1>标题</h1>
 <a href="javascript:void(0) onclick="changeFont(24px)"  ">大字体</a>
 <a href="javascript:void(0) onclick="changeFont(16px)" ">中字体</a>
 <a href="javascript:void(0) onclick="changeFont(10px)" ">小字体</a>
 <hr>
 <div id="newstext" style="font-size: 26px">
达叔小生
 </div>

<script text="text/javascript">
function changeFont(size){
 var divNode=document.getElementById("newstext");
 // divNode.style.font-size
 divNode.style.font-size = size;
}
</script>

样式封装

    .maxfont{
        font-size: 24px;
        color:#66CCFF;
        background-color: #FFCCFF;
    }
    .normfont{
        font-size: 16px;
        color:#686868;
        background-color: #FFFFFF;
    }
    .minfont{
        font-size: 12px;
        color:#FF3300;
        background-color: #99FF99;

    <script type="text/javascript">
        function changeFont(classValue){
            var divNode = document.getElementById("newstext");
            divNode.className = classValue;
        }
    </script>

<div id="newstext" class="normfont" >
</div>

表单校验

  1. 明确事件源和事件
  2. 提示信息展示方式
    <form id="formid" onsubmit="return checkForm()">
        用户名称:<input type="text" name="user" onblur="checkUser()" />
            <span id="userspan"></span><br />
    </form>

    <hr>
    <input type="button" value="自定义提交" onclick="myCheckForm()" />
// 校验方法
        function checkUser() {
            var flag = false;
            var userNode = document.getElementsByName("user")[0];
            var username = userNode.value;
            var spanNode = document.getElementById("userspan");

            // 对用户名进行正则表达式的判断
            var regex = new RegExp("^[a-zA-Z]{4}$");
            if (regex.test(username)) {
                spanNode.innerHTML = "用户名正确".fontcolor("green");
                flag = true;
            } else {
                spanNode.innerHTML = "用户名错误".fontcolor("red");
            }
            return flag;
        }
//校验表单。
        function checkForm() {
            if (checkUser()) {
                return true;
            }
            return false;
        }

表单校验

function myCheckForm() {
//获取表单对象。
 var formNode = document.getElementById("formid");
 if (checkUser()) {
  //调用提交方法
  formNode.submit();
 }
}

    <form id="formid" onsubmit="return checkForm()">
        用户名称:<input type="text" name="user" onblur="checkUser()" />
            <span id="userspan"></span><br />
    </form>
    <hr>
    <input type="button" value="自定义提交" onclick="myCheckForm()" />

效果案例:

<body>
    <!--
因为标签都在文档中,所以想要获取标签需要先有document对象
    getElementById 获取对 ID 标签属性为指定值的第一个对象的引用
    getElementsByName 根据 NAME 标签属性的值获取对象的集合
    getElementsByTagName 获取基于指定元素名称的对象集合
     -->
    <script type="text/javascript">
        function documentDemo(){
            var divNode = document.getElementById("divid");
            //alert(divNode.nodeName);//获取节点的名称。
            //alert(divNode.innerHTML);//获取div中的文本
            divNode.innerHTML = "新文本".fontcolor("red");
        }
        function documentDemo2(){
            //getElementsByName
            //var nodes = document.getElementsByName("user");
            //alert(nodes[0].value);
            var node = document.getElementsByName("user")[0];
            node.value = "hehe";
        }
        function documentDemo3(){
            //getElementsByTagName
            //获取文档中所有的div
            var divNodes = document.getElementsByTagName("div");
            //遍历div节点
            for(var x=0; x<divNodes.length; x++){
                //alert(divNodes[x].innerHTML);
            }
            //需求:获取表格中所有的div。
            var tableNode = document.getElementById("tableid");
            var divNodes2 = tableNode.getElementsByTagName("div");
            for(var y=0; y<divNodes2.length; y++){
                alert(divNodes2[y].innerHTML);
            }
        }
        //按照节点层次关系获取节点。
        function getNodeByLevel(){
            //获取表格节点
            var tableNode = document.getElementById("tableid");
            //1,获取表格节点父节点
            //var node = tableNode.parentNode;
            //alert(node.nodeName);
            //2,获取表格节点的子节点。
            /*
            var nodes = tableNode.childNodes[0].childNodes;
            for(var z=0; z<nodes.length; z++){
                alert(nodes[z].nodeName);
            }
            */
            //3,获取兄弟节点。有可能会获取到空文本节点。
            var node = tableNode.nextSibling;
            //alert("nextSibling:"+node.nodeName);
            var node2 = tableNode.previousSibling;
            //alert("previousSibling:"+node2.nodeName);
        }
    </script>

    <input type="button" value="演示Document对象" onclick="getNodeByLevel()" />
    <div id="divid">DIV</div>
    <table id="tableid">
        <tr>
            <td>一</td>
            <td>二</td>
        </tr>
        <tr>
            <td><div>三</div></td>
            <td><div>四</div></td>
        </tr>
    </table>
</body>

下拉菜单

选择国家:
<select name="country" >
 <option value="none">--选择国家--</option>
 <option value="cn">中国</option>
 <option value="usa">美国</option>
 <option value="en">英国</option>
</select>
<span id="countryspan" ></span><br/>
        //校验国家
        function checkCountry(){
            var flag = true;
            //获取下拉菜单对象
            var selNode = document.getElementsByName("country")[0];
            //获取所有的option对象的集合
            var optNodes = selNode.options;
            var spanNode = document.getElementById("countryspan");
            var val = optNodes[selNode.selectedIndex].value;
            if(val=="none"){
                spanNode.innerHTML = "必须选择一个国家".fontcolor("red");
                flag = false;
            }

            return flag;
        }

        选择国家:
            <select name="country" >
                <option value="none">--选择国家--</option>
                <option value="cn">中国</option>
                <option value="usa">美国</option>
                <option value="en">英国</option>
            </select>
            <span id="countryspan" ></span><br/>

js基于对象的,可以面试对象的方式进行开发

面向对象,需要对对象进行描述,js 可以实现描述,通过函数来完成.

// 描述对象
var a = new Person();
// 给定义的对象添加属性和行为
for(x in arr){
 alert("x="+x);
}

达叔小生:往后余生,唯独有你
You and me, we are family !
90后帅气小伙,良好的开发习惯;独立思考的能力;主动并且善于沟通
简书博客: 达叔小生
https://www.jianshu.com/u/c785ece603d1

结语

  • 下面我将继续对 其他知识 深入讲解 ,有兴趣可以继续关注
  • 小礼物走一走 or 点赞

原文地址:https://www.cnblogs.com/dashucoding/p/10094230.html

时间: 2024-08-24 22:50:39

第61节:Java中的DOM和Javascript技术的相关文章

JAVA中使用DOM解析XML文件

JAVA中使用DOM解析XML文件: 创建DocumentBuilderFactory的对象                                 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); 创建DocumentBuilder对象 通过documentBuilder对象的parser方法加载xml文件到当前项目下 获取所有XML文件内节点的集合    getElementsByTagName()方

第80节:Java中的MVC设计模式

前言 了解java中的mvc模式.复习以及回顾! 事务,设置自动连接提交关闭. setAutoCommit(false); conn.commit(); conn.rollBack 隔离级别分别有: 读未提交有脏读 读已提交有不可重复读 可重复读有幻读 可串行化可以解决脏读,幻读,不可重复读 数据库连接池用于创建和管理连接对象. DBCP和C3P0,分别了解代码设置和配置文件设置 DBUtils可以简化数据的增删改查. QueryRunner runner = new QueryRunner()

Java中导入导出Excel -- POI技术

一.介绍: 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已经习惯用Excel打印.这样在我们实际的开发中,很多时候需要实现导入.导出Excel的应用. 目前,比较常用的实现Java导入.导出Excel的技术有两种Jakarta POI和Java Excel 下面我就分别讲解一下如何使用这两个技术实现导入.导出Excel 二.使用Jakarta POI导入.导出Excel Jakarta PO

第70节:Java中xml和tomcat

前言: 哭着也要看完,字数: jdbc crud - statement dao java.sql.Driver The interface that every driver class must implement. The Java SQL framework allows for multiple database drivers. Each driver should supply a class that implements the Driver interface. The Dr

java 第50节 Java中的异常链

2016-06-30 1 异常链 两个或多个不同的异常出现在同一个程序中,并且会发生嵌套抛出,我们称之为异常链. package com.java1995; /** * 异常链 * @author Administrator * */ public class ExceptionChainTest { public static void main(String[] args) { Calculator c=new Calculator(); try{ c.chufa(1, 0); }catch

[学习手记] Java中利用DOM方法解析XML文件

需求分析: 在做一个利用API的小东西时需要对返回的XML格式的数据进行解析 详见文章: [开发手记] 一款基于命令行的英英词典 (A CLI-Based EE Dictionary) 项目地址: https://github.com/hwding/seekDict 准备工作: 阅读Documentation 查阅相关代码 读入XML文件到程序内: 首先用DocumentBuilderFactory生成一个DocumentBuilder实例 DocumentBuilder docmumentBu

第77节:Java中的事务和数据库连接池和DBUtiles

前言 看哭你,字数:8803,承蒙关照,谢谢朋友点赞! 事务 Transaction事务,什么是事务,事务是包含一组操作,这组操作里面包含许多个单一的逻辑,只要有一个逻辑没有执行成功就算失败,导致回滚就是指所有的数据都会回到最初的状态. 有事务,是为了保证逻辑一定要成功,如银行转账. 回顾一下 什么是jsp,jsp的三大指令. page: 定义当前页面的信息 include: 包含其他页面 taglib: 引入标签库 三大动作标签: <jsp:forward page="">

第78节:Java中的网络编程(上)

前言 网络编程涉及ip,端口,协议,tcp和udp的了解,和对socket通信的网络细节. 网络编程 OSI开放系统互连 网络编程指IO加网络 TCP/IP模型: 应用层 传输层 网际层 主机到网络层 OSI模型:(封装) 网络1封包->网络2拆包 应用层 表示层 会话层 传输层 网络层 数据链路层 物理层 网络通讯要素: ip地址 端口号 传输协议 主机名和ip地址是对应的,默认的主机名:localhost java.net 类 InetAddress java.lang.Object ->

第82节:Java中的学生管理系统

学生管理系统的删除功能 删除,点击超链接,点击弹出对话框式是否进行删除,如果确定,就删除,超链接执行的是js方法,在js里访问,跳转servlet,,servlet中调用dao方法. <a href="#" onclick="doDelete(${stu.sid})">删除</a> <script type="text/javascript"> function doDelete(sid) { // 弹出对话框