JAVAEE 实训日志02_20200705 下

文章目录

    • Spring MVC
    • 前端技术
      • CSS
        • 引入方式
        • CSS 选择器
      • JavaScript
      • JavaScript 静态页面
      • JQuery
        • 基本语法
        • JQuery 技巧
          • 1、关于页面元素的引用
          • 2、jQuery对象与dom对象的转换
          • 3、如何获取jQuery集合的某一项
          • 4、同一函数实现set和get
          • 5、集合处理功能
          • 6、扩展我们需要的功能
          • 7、支持方法的连写
          • 8、操作元素的样式
          • 9、完善的事件处理功能
          • 10、几个实用特效功能
          • 11、几个有用的jQuery方法
          • 12、解决自定义方法或其他类库与jQuery的冲突
      • Ajax

Spring MVC

DispatcherServlet 是 HttpServlet的子类
jsp = jsp 1.0 客户端技术
jstl = jsp 2.0 客户端技术

前端技术

CSS

引入方式

  1. 内联格式 inline
    直接在html标签元素内嵌入css样式:
我是机器人
  1. style block
    在html头部的head内,利用style声明插入代码:
  1. css文件导入
    使用link来调用外部的css文件
将调用外部的style.css文件来实现html引用css文件

CSS 选择器

  1. 通用选择器
    通用选择器用*来表示。例如:
    *{
    font-size: 12px;
    }
    表示所有的元素的字体大小都是12px;同时通用选择器还可以和后代选择器组合。

  2. 类选择器(ID指定选择器 人工手段 集合选择)
    类选择器根据类名来选择,是一对多的映射
    前面以”.”来标志,如:

<!--字体颜色为红色的类-->
.style1{
    color:#FF0000;
}
调用方式:
<div class="style1">
     区域字体颜色为红色
</div>
   
<p class="style1">
     段落字体颜色为红色
</p>

  1. 标签选择器(属性适配选择,自动化)
    标签选择器又称为元素选择器,决定哪类标签采用对应的CSS样式,是一对多的映射
<!--定义table边框设置宽度,类型,颜色 .表格背景颜色,字体大小-->
table {
	font-size:12px;
	border: 1px solid #CCCCCC; background-image:url(B_r16_c3.gif);
	 
}
<!--下面是td边框设置成无 ,字体大小,高度-->
td{ border: none;
	font-size: 12px;
	height: 25px; 
}
————————————————————
和类选择器合用:
 p.bgstyle { background:#ff0; }

调用方式:
<p class="bgstyle">
黑色字体背景黄色
</p>

  1. ID选择器(ID锁定,1对1 个体)
    ID 选择器可以为标有特定 ID 的 HTML 元素指定特定的样式。在页面内为一对一映射
    前面以”#”号来标志:
#div001{
  color:#FF0000;
}
这里代表id为div001的元素,字体颜色为红色。

调用方式:
<div id="div001">
   区域字体颜色为红色
</div>

————————————————————
和标签选择器合用:
 p#bg01 { background:#ff0; }

调用方式:
<p id="bg01">
黑色字体背景黄色
</p>

  1. 后代选择器
    后代选择器(包含选择器),用来选择特定元素或元素组的后代(集合).父元素拣选在前面,子元素拣选在后面,中间用空格分割。
.father .child{
color:#0000CC;
}

调用方式:
<p class="father">
黑色
<label class="child">蓝色
<b>也是蓝色</b>
</label>
</p>
————————————
通用+后代
p *{
color:#00CC00;
}
表示所有p元素后代的所有元素都应用这个样式。这种方式容易混淆,慎用

  1. 关系选择器
    关系选择器又称为组合选择器:

选择器 含义 示例

E,F		多元素选择器,同时匹配所有E元素或F元素,E和F之间用逗号分隔			Div,p { color:#f00; }

E F 		后代元素选择器,匹配所有属于E元素后代的F元素,E和F之间用空格分隔	#nav li { display:inline; }
																	li a { font-weight:bold; }
E > F	子元素选择器,匹配所有E元素的子元素F						div > strong { color:#f00; }

E + F	毗邻元素选择器,匹配所有紧随E元素之后的同级元素F				p + p { color:#f00;  }

  1. 伪类选择器(事件选择,用户行为)
    有时候还会需要用各种事件这样的非文档选择。例如链接应用的伪类定义。
a:link{
color:#999999;
}
a:visited{
color:#FFFF00;
}
a:hover{
color:#006600;
}
/* IE不支持,用w3c浏览器可以看到效果 */
input:focus{
background:# E0F1F5;
}
  1. 属性选择器
    选择器 含义 示例
E[att]		匹配所有具有att属性的E元素,不考虑它的值。				p[title] { color:#f00; }
			(注意:E在此处可以省略,比如“[checked]”)
	
E[att=val]	匹配所有att属性等于“val”的E元素						div[class="error"] { color:#f00; }

E[att~=val]	匹配所有att属性具有多个空格分隔的值、					td[class~="name"] { color:#f00; }
			其中一个值等于“val”的E元素
E[att|=val]	匹配所有att属性具有多个连字号分隔(hyphen-separated)		p[lang|=en] { color:#f00; }
			的值、其中一个值以“val”开头的E元素,主要用于lang属性,
			比如“en”、“en-us”、“en-gb”等等

JavaScript

一、引入方式

  1. js文件导入

  2. 内联格式 inline

二、调试

  1. IDE环境的调试工具 , idea,eclipse

  2. 浏览器的调试工具
    IE F2功能键
    Firefox firebug
    Mozilla Venkman

  3. 其他工具
    Drosera ,WebKit javascript 调试工具
    Dragonfly
    Debugbar

三、网页系统资源

  1. 页面内置对象树
    浏览器对象 navigator
    屏幕对象 screen
    窗口对象 window
      历史对象 history
      地址对象 location
      框架对象 frames[]; Frame
      文档对象 document
       连接对象 anchors[]; links[]; Link
       Java小程序对象 applets[]
       插件对象 embeds[]
       图片对象 images[]; Image
       表单对象 forms[]; Form
        按钮对象 Button
        复选框对象 Checkbox
        表单元素对象 elements[]; Element
        隐藏对象 Hidden
        密码输入区对象 Password
        单选域对象 Radio
        重置按钮对象 Reset
        选择区(下拉菜单、列表)对象 Select
         选择项对象 options[]; Option
        提交按钮对象 Submit
        文本框对象 Text
        多行文本输入区对象 Textarea

  2. 运行事件
    onLoad, onUnLoad
    onClick,onSubmit
    onBlur, onFocus
    onResize,onError

    onKeyDown,onKeyUp,onKeyPress
    onMouseDown,onMouseUp,onMouseOut

  3. 操作行为 (window)
      alert() 打开一个Alert消息框
      clearTimeout() 用来终止setTimeout方法的工作
      close() 关闭窗口
      confirm() 打开一个Confirm消息框,用户可以选择OK或Cancel,如果用户单击OK,该方法返回true,单击Cancel返回false
      blur() 把焦点从指定窗口移开(这是Netscape Navigator 3.0 beta 3引入的新方法)
      focus() 把指定的窗口带到前台(另一个新方法)
      open() 打开一个新窗口
      PRompt() 打开一个Prompt对话框,用户可向该框键入文本,并把键入的文本返回到脚本
      setTimeout() 等待一段指定的毫秒数时间,然后运行指令事件处理程序
    clearTimeout() 清除定时事件

  4. 常用内置对象
    4.1【window对象】

它是一个顶层对象,而不是另一个对象的属性即浏览器的窗口。

4.1.1属性
  defaultStatus 缺省的状态条消息
  document 当前显示的文档(该属性本身也是一个对象)
  frame 窗口里的一个框架((FRAME>)(该属性本身也是一个对象)
  frames array 列举窗口的框架对象的数组,按照这些对象在文档中出现的顺序列出(该属性本身也是一个对象)
  history 窗口的历史列表(该属性本身也是一个对象)
  length 窗口内的框架数
  location 窗口所显示文档的完整(绝对)URL(该属性本身也是一个对象)不要把它与如document.location混淆,后者是当前显示文档的URL。用户可以改变window.location(用另一个文档取代当前文档),但却不能改变document.location(因为这是当前显示文档的位置)
  name 窗口打开时,赋予该窗口的名字
  opener 代表使用window.open打开当前窗口的脚本所在的窗口(这是Netscape Navigator 3.0beta 3所引入的一个新属性)
  parent 包含当前框架的窗口的同义词。frame和window对象的一个属性
  self 当前窗口或框架的同义词
  status 状态条中的消息
  top 包含当前框架的最顶层浏览器窗口的同义词
  window 当前窗口或框架的同义词,与self相同

4.2【document对象】

该对象是window和frames对象的一个属性,是显示于窗口或框架内的一个文档。

4.2.1属性

alinkColor 活动链接的颜色(ALINK)
  anchor 一个HTMI锚点,使用标记创建(该属性本身也是一个对象)
  anchors array 列出文档锚点对象的数组(
)(该属性本身也是一个对象)
  bgColor 文档的背景颜色(BGCOLOR)
  cookie 存储于cookie.txt文件内的一段信息,它是该文档对象的一个属性
  fgColor 文档的文本颜色(标记里的TEXT特性)
  form 文档中的一个窗体()(该属性本身也是一个对象)
  forms anay 按照其出现在文档中的顺序列出窗体对象的一个数组(该属性本身也是一个对象)
  lastModified 文档最后的修改日期
  linkColor 文档的链接的颜色,即标记中的LINK特性(链接到用户没有观察到的文档)
  link 文档中的一个
标记(该属性本身也是一个对象)
  links array 文档中link对象的一个数组,按照它们出现在文档中的顺序排列(该属性本身也是一个对象)
  location 当前显示文档的URL。用户不能改变document.location(因为这是当前显示文档的位置)。但是,可以改变window.location (用其它文档取代当前文档)window.location本身也是一个对象,而document.location不是对象
  referrer 包含链接的文档的URL,用户单击该链接可到达当前文档
  title 文档的标题((TITLE>)
  vlinkColor 指向用户已观察过的文档的链接文本颜色,即标记的VLINK特性

4.3【forms[]; Form 表单对象】
4.3.1用法
document.forms[] 是一个数组,包含了文档中所有的表单()。要引用单个表单,可以用 document.forms[x],但是一般来说,人们都会这样做:在标记中加上“name="…"”属性,那么直接用 “document.<表单名>”就可以引用了。

4.3.2属性
name 返回表单的名称,也就是属性。
action 返回/设定表单的提交地址,也就是属性。
method 返回/设定表单的提交方法,也就是属性。
target 返回/设定表单提交后返回的窗口,也就是属性。
encoding 返回/设定表单提交内容的编码方式,也就是属性。
length 返回该表单所含元素的数目。

4.3.3方法
reset() 重置表单。这与按下“重置”按钮是一样的。
submit() 提交表单。这与按下“提交”按钮是一样的。

4.3.4事件
onreset
onsubmit

JavaScript 静态页面

一. 客户端程序与 服务器端程序的区别和联系。

什么是客户端(Client Side )程序

什么是服务器端(Server Side )程序

客户端程序与服务器端程序的运行机制。

二. 客户端开发:

  1. HTML 静态页面的结构;
页面字符集 charset,(utf-8,gb2312,gbk,shiftJIS,EUCJP)

<meta http-equiv="Content-Type" content="text/html; charset=8859-1" />
  1. FORM 元素
<FORM name="theform" method="post" action="mailto:" onSubmit="return formCheck();"> </FORM>


<INPUT type="text" name="user_name">


<INPUT type=="submit" name="提交">
  1. TABLE 元素
<TABLE width="300" border="0" cellspacing="0" cellpadding="0" align="center">

</TABLE>

<TR> </TR>

<TD width ="100" heigh ="30"> </TD>

  1. 表单提交的方式
submit 按钮;

<INPUT type=="submit" value="提交" name="commit">

button按钮 onClick事件+document.form.submit()<INPUT type=="button" value="提交" name="commit" onclick="javascript:sub(1);">

{

document.form.submit();

}

Onsubmit()事件;

<FORM name="theform" method="post" action="mailto:" onSubmit="return formCheck();">

  1. JavaScript / JScript
函数定义;

function sub1(type){

return true;

}

提交事件;

{

document.form.submit();

}

表单元素的值;

documet.form1.name.value

document.form1.sendType[i].value

document.form1.sendType[i].checked

  1. js表单客户端验证
实例: 用户名/密码

function formCheck() {

if (document.theform.user_name.value == "") /**判断是否填写了姓名*/

{

alert("请输入您的名字");/**弹出提示窗口*/

return false;

}

if ( document.theform.password.value=="") /**判断是否填写了密码*/

{

alert("请输入您的密码");

return false;

}

}

三. 界面Demo

登录界面;

列表页面;

详细页面;

新建页面;

更新页面;

四. 服务器端开发

1. Scriptlet 、指令、表达式

<%

out("Hello world !");

%>


<%@ page import="java.util.*, java.lang.*" %>

<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>


<%= name1 %>

2. request、session、application 对象数据传递。

request.getParameter("name")

session.getAttribute( "theName" )

String ssk="hello";

application.setAttribute("name",ssk);

3. Tags

<jsp:forward page="/servlet/login">

<jsp:param name="username" value="jsmith" />

</jsp:forward>


<jsp:useBean id="calendar" scope="page" class="employee.Calendar" />

<jsp:getProperty name="calendar" property="username" />


<jsp:useBean id="checking" scope="session" class="bank.Checking" >

<jsp:setProperty name="checking" property="balance" value="0.0" />

</jsp:useBean>

4. Java bean 数据传递

<jsp:useBean id="checking" scope="session" class="bank.Checking" >

<jsp:setProperty name="checking" property="balance" value="0.0" />

</jsp:useBean>

<jsp:useBean id="calendar" scope="page" class="employee.Calendar" />

<jsp:getProperty name="calendar" property="username" />

JQuery

基本语法

基本语法:
$(“HTML元素”).action()
实例:
$(this).hide(); 隐藏当前元素
$(“p”).hide(); 隐藏所有段落
$(“p.test”).hide(); 隐藏所有 class=”test”的段落
$(“#test”).hide(); 隐藏所有id=”test”的元素
文档就绪函数
$(document).ready(function(){
——–
});
这是为了防止文档在完全加载(就绪)之前运行 jQuery 代码。
下面是两种假如文档完全加载之前运行函数的话,操作失败的情况:
?试图隐藏一个不存在的元素。
?获得未完全加载的图像的大小。
.divcss{
background-color:#e5eecc;
padding:7px;
border:solid 1px #c3c3c3;
}
jQuery 元素选择器
jQuery 使用 CSS 选择器来选取 HTML 元素。
$(“p”) 选取 

元素。 $(“p.intro”) 选取所有 class=”intro” 的

元素。 $(“p#demo”) 选取 id=”demo” 的第一个

元素。 jQuery 属性选择器 jQuery 使用 XPath 表达式来选择带有给定属性的元素。 $(“[href]“) 选取所有带有 href 属性的元素。 $(“[href='#']“) 选取所有带有 href 值等于 “#” 的元素。 $(“[href!='#']“) 选取所有带有 href 值不等于 “#” 的元素。 $(“[href$='.jpg']“) 选取所有 href 值以 “.jpg” 结尾的元素。 jQuery CSS 选择器 jQuery CSS 选择器可用于改变 HTML 元素的 CSS 属性。 下面的例子把所有 p 元素的背景颜色更改为红色: $(“p”).css(“background-color”,”red”); 更多实例 $(this) 当前 HTML 元素 $(“p”) 所有

元素 $(“p.intro”) 所有 class=”intro” 的

元素 $(“.intro”) 所有 class=”intro” 的元素 $(“#intro”) id=”intro” 的第一个元素 $(“ul li:first”) 每个

    的第一个
  • 元素 $(“[href$='.jpg']“) 所有带有以 “.jpg” 结尾的 href 属性的属性 (“div#intro .head”) id=”intro” 的
    元素中的所有 class=”head” 的元素 jQuery 事件函数 jQuery 事件处理函数是 jQuery 中的核心函数。 事件处理函数是当 HTML 中发生事件时自动被调用的函数。 由“事件”(event)“触发”(triggered)是经常被用到的术语。 jQuery 名称冲突 jQuery 使用 $ 符号作为 jQuery 的简介方式。 某些其他 JavaScript 库中的函数(比如 Prototype)同样使用 $ 符号。 jQuery 使用名为 noConflict() 的方法来解决该问题。 var jq=jQuery.noConflict(),帮助您使用自己的名称(比如 jq)来代替 $ 符号。 jQuery 事件 下面是 jQuery 中事件函数的一些例子: $(document).ready(function) 文档的就绪事件(当 HTML 文档就绪可用) $(selector).click(function) 被选元素的点击事件 $(selector).dblclick(function) 被选元素的双击事件 $(selector).focus(function) 被选元素的获得焦点事件 $(selector).mouseover(function) 被选元素的鼠标悬停事件 jQuery 隐藏和显示 通过 hide() 和 show() 两个函数,jQuery 支持对 HTML 元素的隐藏和显示: hide() 和 show() 都可以设置两个可选参数:speed 和 callback。 callback 参数是在 hide 或 show 函数完成之后被执行的函数名称 speed 参数可以设置这些值:”slow”, “fast”, “normal” 或 milliseconds jQuery 切换 jQuery toggle() 函数使用 show() 或 hide() 函数来切换 HTML 元素的可见状态。 隐藏显示的元素,显示隐藏的元素。 speed 参数可以设置这些值:”slow”, “fast”, “normal” 或 milliseconds jQuery 滑动函数 - slideDown, slideUp, slideToggle jQuery 拥有以下滑动函数: $(selector).slideDown(speed,callback) $(selector).slideUp(speed,callback) $(selector).slideToggle(speed,callback) peed 参数可以设置这些值:”slow”, “fast”, “normal” 或 毫秒。 callback 参数是在 hide 或 show 函数完成之后被执行的函数名称。 jQuery Fade 函数 - fadeIn(), fadeOut(), fadeTo() jQuery 拥有以下 fade 函数: $(selector).fadeIn(speed,callback) $(selector).fadeOut(speed,callback) $(selector).fadeTo(speed,opacity,callback) peed 参数可以设置这些值:”slow”, “fast”, “normal” 或 毫秒。 fadeTo() 函数中的 opacity 参数规定减弱到给定的不透明度。 allback 参数是在 hide 或 show 函数完成之后被执行的函数名称。 jQuery 自定义动画 jQuery 函数创建自定义动画的语法: $(selector).animate({params},[duration],[easing],[callback])关键的参数是 params。 它定义了产生动画的属性。可以同时设置多个此类属性: animate({width:”70%”,opacity:0.4,marginLeft:”0.6in”,fontSize:”3em”}); 第二个参数是 duration。它定义用来应用于动画的时间。 它设置的值是:”slow”, “fast”, “normal” 或 毫秒。 HTML 元素默认是静态定位,且无法移动。 如需使元素可以移动,请把 CSS 的 position 设置为 relative 或 absolute。 改变 HTML 内容 语法 $(selector).html(content)html() 函数改变所匹配的 HTML 元素的内容(innerHTML)。 添加 HTML 内容 语法 $(selector).append(content)append() 函数向所匹配的 HTML 元素内部追加内容。 语法 $(selector).after(content)after() 函数在所有匹配的元素之后插入 HTML 内容。 语法 $(selector).before(content)before() 函数在所有匹配的元素之前插入 HTML 内容。 jQuery CSS 操作 jQuery 拥有三种供 CSS 操作的重要函数: ?$(selector).css(name,value) ?$(selector).css({properties}) ?$(selector).css(name) CSS 操作实例 函数 css(name,value) 为所有匹配元素的给定 CSS 属性设置值: 实例 $(selector).css(name,value) $(“p”).css(“background-color”,”yellow”); 函数 css({properties}) 同时为所有匹配元素的一系列 CSS 属性设置值: 实例 $(selector).css({properties}) $(“p”).css({“background-color”:”yellow”,”font-size”:”200%”}); 函数 css(name) 返回指定的 CSS 属性的值: 实例 $(selector).css(name) $(this).css(“background-color”); jQuery Size 操作 jQuery 拥有两种供尺寸操作的重要函数: ?$(selector).height(value) ?$(selector).width(value) Size 操作实例 函数 height(value) 设置所有匹配元素的高度: 实例 $(selector).height(value) $(“#id100″).height(“200px”); 函数 width(value) 设置所有匹配元素的宽度: 实例 $(selector).width(value) $(“#id200″).width(“300px”); AJAX 和 jQuery Query 的 load 函数是一种简单的(但很强大的)AJAX 函数。它的语法如下: $(selector).load(url,data,callback) 请使用选择器来定义要改变的 HTML 元素,使用 url 参数来指定您的数据的 web 地址。 只有当您希望向服务器发送数据,才需要使用 data 参数。 只有当您需要在完毕之后触发一个函数时,您才需要使用 callback 参数。 jQuery AJAX 请求 请求 描述 $(selector).load(url,data,callback) 把远程数据加载到被选的元素中 $.ajax(options) 把远程数据加载到 XMLHttpRequest 对象中 $.get(url,data,callback,type) 使用 HTTP GET 来加载远程数据 $.post(url,data,callback,type) 使用 HTTP POST 来加载远程数据 $.getJSON(url,data,callback) 使用 HTTP GET 来加载远程 JSON 数据 $.getScript(url,callback) 加载并执行远程的 JavaScript 文件 (selector) jQuery 元素选择器语法 (url) 被加载的数据的 URL(地址) (data) 发送到服务器的数据的键/值对象 (callback) 当数据被加载时,所执行的函数 (type) 被返回的数据的类型 (html,xml,json,jasonp,script,text) (options) 完整 AJAX 请求的所有键/值对选项

JQuery 技巧

1、关于页面元素的引用

通过jquery的$()引用元素包括通过id、class、元素名以及元素的层级关系及dom或者xpath条件等方法,且返回的对象为jquery对象(集合对象),不能直接调用dom定义的方法。

2、jQuery对象与dom对象的转换

只有jquery对象才能使用jquery定义的方法。注意dom对象和jquery对象是有区别的,调用方法时要注意操作的是dom对象还是jquery对象。
普通的dom对象一般可以通过 ( ) 转 换 成 j q u e r y 对 象 。 如 : ()转换成jquery对象。 如: ()jquery(document.getElementById(“msg”))则为jquery对象,可以使用jquery的方法。
由于jquery对象本身是一个集合。所以如果jquery对象要转换为dom对象则必须取出其中的某一项,一般可通过索引取出。
如:KaTeX parse error: Expected 'EOF', got '#' at position 3: ("#̲msg")[0],(“div”).eq(1)[0], ( " d i v " ) . g e t ( ) [ 1 ] , ("div").get()[1], ("div").get()[1](“td”)[5]这些都是dom对象,可以使用dom中的方法,但不能再使用Jquery的方法。
以下几种写法都是正确的:
$("#msg").html();
$("#msg")[0].innerHTML;
$("#msg").eq(0)[0].innerHTML;
$("#msg").get(0).innerHTML;

3、如何获取jQuery集合的某一项

对于获取的元素集合,获取其中的某一项(通过索引指定)可以使用eq或get(n)方法或者索引号获取,要注意,eq返回的是jquery对象,而get(n)和索引返回的是dom元素对象。对于jquery对象只能使用jquery的方法,而dom对象只能使用dom的方法,如要获取第三个

元素的内容。有如下两种方法:
$(“div”).eq(2).html(); //调用jquery对象的方法
$(“div”).get(2).innerHTML; //调用dom的方法属性

4、同一函数实现set和get
Jquery中的很多方法都是如此,主要包括如下几个:
$("#msg").html();    //返回id为msg的元素节点的html内容。
$("#msg").html("new content"); 
//将“<b>new content</b>” 作为html串写入id为msg的元素节点内容中,页面显示粗体的new content

$("#msg").text();    //返回id为msg的元素节点的文本内容。
$("#msg").text("new content"); 
//将“<b>new content</b>” 作为普通文本串写入id为msg的元素节点内容中,页面显示<b>new content</b>

$("#msg").height();    //返回id为msg的元素的高度
$("#msg").height("300"); //将id为msg的元素的高度设为300
$("#msg").width();    //返回id为msg的元素的宽度
$("#msg").width("300"); //将id为msg的元素的宽度设为300

$("input").val("); //返回表单输入框的value值
$("input").val("test"); //将表单输入框的value值设为test

$("#msg").click(); //触发id为msg的元素的单击事件
$("#msg").click(fn); //为id为msg的元素单击事件添加函数
同样blur,focus,select,submit事件都可以有着两种调用方法
5、集合处理功能
对于jquery返回的集合内容无需我们自己循环遍历并对每个对象分别做处理,jquery已经为我们提供的很方便的方法进行集合的处理。
包括两种形式:
$("p").each(function(i){this.style.color=['#f00','#0f0','#00f'][ i ]}) 
//为索引分别为0,1,2的p元素分别设定不同的字体颜色。

$("tr").each(function(i){this.style.backgroundColor=['#ccc','#fff'][i%2]}) 
//实现表格的隔行换色效果

$("p").click(function(){alert($(this).html())})    
//为每个p元素增加了click事件,单击某个p元素则弹出其内容
6、扩展我们需要的功能
$.extend({
min: function(a, b){return a < b?a:b; },
max: function(a, b){return a > b?a:b; } 
}); //为jquery扩展了min,max两个方法
使用扩展的方法(通过“$.方法名”调用):
alert("a=10,b=20,max="+$.max(10,20)+",min="+$.min(10,20));
7、支持方法的连写

所谓连写,即可以对一个jquery对象连续调用各种不同的方法。
例如:

$("p").click(function(){alert($(this).html())})
.mouseover(function(){alert('mouse over event')})
.each(function(i){this.style.color=['#f00','#0f0','#00f'][ i ]});
8、操作元素的样式

主要包括以下几种方式:
$("#msg").css(“background”); //返回元素的背景颜色
$("#msg").css(“background”,"#ccc") //设定元素背景为灰色
$("#msg").height(300); $("#msg").width(“200”); //设定宽高
$("#msg").css({ color: “red”, background: “blue” });//以名值对的形式设定样式
$("#msg").addClass(“select”); //为元素增加名称为select的class
$("#msg").removeClass(“select”); //删除元素名称为select的class
$("#msg").toggleClass(“select”); //如果存在(不存在)就删除(添加)名称为select的class

9、完善的事件处理功能

Jquery已经为我们提供了各种事件处理方法,我们无需在html元素上直接写事件,而可以直接为通过jquery获取的对象添加事件。
如:
$("#msg").click(function(){alert(“good”)}) //为元素添加了单击事件
$(“p”).click(function(i){this.style.color=[’#f00’,’#0f0’,’#00f’][ i ]})
//为三个不同的p元素单击事件分别设定不同的处理
jQuery中几个自定义的事件:
(1)hover(fn1,fn2):一个模仿悬停事件(鼠标移动到一个对象上面及移出这个对象)的方法。当鼠标移动到一个匹配的元素上面时,会触发指定的第一个函数。当鼠标移出这个元素时,会触发指定的第二个函数。
//当鼠标放在表格的某行上时将class置为over,离开时置为out。

$("tr").hover(function(){
$(this).addClass("over");
},
function(){
$(this).addClass("out"); 
});

(2)ready(fn):当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。
( d o c u m e n t ) . r e a d y ( f u n c t i o n ( ) a l e r t ( " L o a d S u c c e s s " ) ) / / 页 面 加 载 完 毕 提 示 “ L o a d S u c c e s s ” , 相 当 于 o n l o a d 事 件 。 与 (document).ready(function(){alert("Load Success")}) //页面加载完毕提示“Load Success”,相当于onload事件。与 (document).ready(function()alert("LoadSuccess"))//LoadSuccess,onload(fn)等价
(3)toggle(evenFn,oddFn): 每次点击时切换要调用的函数。如果点击了一个匹配的元素,则触发指定的第一个函数,当再次点击同一元素时,则触发指定的第二个函数。随后的每次点击都重复对这两个函数的轮番调用。
//每次点击时轮换添加和删除名为selected的class。

$("p").toggle(function(){
   $(this).addClass("selected"); 
},function(){
   $(this).removeClass("selected"); 
});
(4)trigger(eventtype): 在每一个匹配的元素上触发某类事件。
例如:
$("p").trigger("click");    //触发所有p元素的click事件
(5)bind(eventtype,fn),unbind(eventtype): 事件的绑定与反绑定
从每一个匹配的元素中(添加)删除绑定的事件。
例如:
$("p").bind("click", function(){alert($(this).text());}); //为每个p元素添加单击事件
$("p").unbind(); //删除所有p元素上的所有事件
$("p").unbind("click") //删除所有p元素上的单击事件
10、几个实用特效功能

其中toggle()和slidetoggle()方法提供了状态切换功能。
如toggle()方法包括了hide()和show()方法。
slideToggle()方法包括了slideDown()和slideUp方法。

11、几个有用的jQuery方法
$.browser.浏览器类型:检测浏览器类型。有效参数:safari, opera, msie, mozilla。如检测是否ie:$.browser.isie,是ie浏览器则返回true。
$.each(obj, fn):通用的迭代函数。可用于近似地迭代对象和数组(代替循环)。
如
$.each( [0,1,2], function(i, n){ alert( "Item #" + i + ": " + n ); }); 
等价于:
var tempArr=[0,1,2];
for(var i=0;i<tempArr.length;i++){
alert("Item #"+i+": "+tempArr[ i ]);
}
也可以处理json数据,如
$.each( { name: "John", lang: "JS" }, function(i, n){ alert( "Name: " + i + ", Value: " + n ); });
结果为:
Name:name, Value:John
Name:lang, Value:JS
$.extend(target,prop1,propN):用一个或多个其他对象来扩展一个对象,返回这个被扩展的对象。这是jquery实现的继承方式。
如:
$.extend(settings, options); 
//合并settings和options,并将合并结果返回settings中,相当于options继承setting并将继承结果保存在setting中。
var settings = $.extend({}, defaults, options);
//合并defaults和options,并将合并结果返回到setting中而不覆盖default内容。
可以有多个参数(合并多项并返回)
$.map(array, fn):数组映射。把一个数组中的项目(处理转换后)保存到到另一个新数组中,并返回生成的新数组。
如:
var tempArr=$.map( [0,1,2], function(i){ return i + 4; });
tempArr内容为:[4,5,6]
var tempArr=$.map( [0,1,2], function(i){ return i > 0 ? i + 1 : null; });
tempArr内容为:[2,3]
$.merge(arr1,arr2):合并两个数组并删除其中重复的项目。
如:$.merge( [0,1,2], [2,3,4] ) //返回[0,1,2,3,4]
$.trim(str):删除字符串两端的空白字符。 
如:$.trim("   hello, how are you? "); //返回"hello,how are you? "
12、解决自定义方法或其他类库与jQuery的冲突
很多时候我们自己定义了$(id)方法来获取一个元素,
或者其他的一些js类库如prototype也都定义了$方法,
如果同时把这些内容放在一起就会引起变量方法定义冲突,
Jquery对此专门提供了方法用于解决此问题。
使用jquery中的jQuery.noConflict();方法
即可把变量$的控制权让渡给第一个实现它的那个库或之前自定义的$方法。
之后应用Jquery的时候只要将所有的$换成jQuery即可,
如原来引用对象方法$("#msg")改为jQuery("#msg")。
如:
jQuery.noConflict(); 
// 开始使用jQuery
jQuery("div p").hide();
// 使用其他库的 $() 
$("content").style.display = 'none';

Ajax

《AJAX中文参考手册》
https://www.php.cn/course/72.html

AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。

AJAX 不是新的编程语言,而是一种使用现有标准的新方法。

AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。

AJAX 不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。

使用Ajax的最大优点,就是能在不更新整个页面的前提下维护数据。这使得Web应用程序更为迅捷地回应用户动作,并避免了在网络上发送那些没有改变的信息。

运用XHTML+CSS来表达信息;

运用JavaScript操作DOM(Document Object Model)来运行动态效果;

运用XML和XSLT操作数据;

运用XMLHttpRequest或新的Fetch API与网页服务器进行异步数据交换;

Ajax应用与传统的Web应用的区别主要在3个地方:

  1. 不刷新整个页面,在页面内与服务器通信。

  2. 使用异步方式与服务器通信,不需要打断用户的操作,具有更加迅速的的响应能力。

  3. 应用仅由少量页面组成。大部分交互在页面之内完成,不需要切换整个页面。

由此可见,Ajax使得Web应用更加动态,带来了更高的智能,并且提供了表现能力丰富的Ajax UI组件。这样一类新型的Web应用叫做RIA(Rich Internet Application)应用。除了Ajax,还包括有Flash等技术。

你可能感兴趣的:(JAVAEE,实训)