一、事件
1 加载DOM
$(document).ready(function(){//...})
DOM加载完毕后执行,在可重复使用上区别于window.onload=function(){//...}
$(window).load(function(){//...})
window内所有对象加载完毕后执行,几等同window.onload=function(){//...}。也可针对selector使用此方法
另:$(document).ready(function(){//...})的简写方式:$(function(){//...})或$().ready(function(){//...})
2 事件绑定
$("selector").bind()
为元素绑定事件,格式:bind(type[,data],fn),可多次调用
type事件类型包括:blur, focus, load, resize, scroll, unload, click, dbclick, mousedown, mouseup, mousemove, mouseover, mouseout, mouseenter, mouseleave, change, select, submit, keydown, keypress, keyup, error或者自定义事件
简写方法:$("selector").bind(type,function(){//...})等价于$("selector").type(function(){//...})
可传递data参数以供unbind特定事件之用
$("selector").is()
判断方法
(外:方法多次重用可定义局部变量 var $x = $("selector").方法())
3 合成事件
$("selector").hover(enter,leave)
模拟光标悬停事件,鼠标进入时触发enter事件,鼠标移出时触发leave事件(代替的是bind("mouseenter")和bind("mouseleave"))
使用方法:$("selector").hover(function(){//enter case...},function(){//leave case...})
(外:IE6不支持除a标签外css的:hover伪类的问题——可用此hover事件作为hack来解决)
$("selector").toggle(fn1,fn2,...,fnN)
模拟鼠标连续单击事件,按照单击顺序按次序循环执行事件
使用方法:$("selector").toggle(function(){//case1...},function(){//case2...},...,function(){//caseN})
特殊用法:切换元素可见状态,如元素隐藏,单击toggle触发元素可使之可见;元素可见,单击toggle触发元素使之隐藏
P108例:
<script> <BR>$(function(){ <BR>$("panel h5.head").toggle(function(){ <BR>$(this).next().toggle(); <BR>},function(){ <BR>$(this).next().toggle(); <BR>}) <BR>}) <BR></script>
4 事件冒泡
$("selector").bind("type",function(event){//event:事件对象...})
event事件对象:只有此函数内部才能访问到,事件处理函数执行完毕后,事件对象就被销毁
event.stopPropagation()
在函数最后用来停止事件冒泡
P111例:
<script> <BR>$('span').bind("click",function(event){ <BR>var txt = $('msg').html() + "<p>内层span元素被单击"; <BR>$('#msg').html(txt); <BR>event.stopPropagation(); <BR>}) <BR></script>
event.preventDefault()
阻止元素默认行为
例:验证表单(input为空阻止提交并提示)
<script> <BR>$(function(){ <BR>$("#submit").bind("click",function(event){ <BR>var username=$("#username").val(); <BR>if(username==""){ <BR>$("#msg").html("<p> 文本框的值不能为空"); <BR>event.preventDefault(); <BR>} <BR>}); <BR>}) <BR></script>
return false;
同时对对象事件停止冒泡和默认行为,等价于同时调用stopPrapagation()和preventDefault()
(外:事件捕获和事件冒泡是相反的过程,事件捕获是从DOM顶端往下开始触发,jQuery不支持,故本书从略)
5 事件对象的属性
event.type
获取事件类型
例:
<script> <BR>$("a").click(function(event){ <BR>alert(event.type); <BR>return false; <BR>}) <BR></script>
上面返回"click"
event.target
获取触发事件的元素
例:
<script> <BR>$("a[href=http://baidu.com]").click(function(){ <BR>alert(event.target.href); <BR>return false; <BR>}) <BR></script>
上面返回"http://baidu.com"
event.relatedTarget
访问事件相关元素
event.pageX / event.pageY
获取光标相对于页面的x坐标和y坐标
event.which
在鼠标单击事件中获取鼠标的左、中、右键;在键盘事件中获取键盘的按键(返回值1=鼠标左键;2=鼠标中键;3=鼠标右键)
event.metaKey
键盘事件中获取
event.originalEvent
指向原始的事件对象
6 移除事件
$("selector").unbind()
移除元素上的事件,格式:$("selector").unbind([type][,data]);(如果没有参数,则删除所有绑定的事件;如果提供了事件类型参数,则只删除该类型的绑定事件;如果把在绑定时传递的处理函数作为第二个参数,则只有这个特定的事件处理函数会被删除)
例:
<script> <BR>$(function(){ <BR>$('#btn').bind("click",myFun1=function(){ //先绑定 <BR>$('#test').append("..."); <BR>}); <BR>}) <BR></script>
<script> <BR>$('#delOne').click(function(){ <BR>$('#btn').unbind("click",myFun1); //后删除 <BR>}) <BR></script>
$("selector").one()
绑定一个触发一次即被删除的事件,格式:$("selector").one(type[,data],fn);
7 模拟操作
$("selector").trigger("type");
模拟用户交互动作,简写方法:$("#selector").type(); 格式:$("selector").trigger(type[,data])
例:用单击替代鼠标经过
<script> <BR>$("selector").mouseover(function{//...}); <BR>$("selector2").click(function(){ <BR>$("selector").trigger("mouseover"); //或者$("selector").mouseover() <BR>}) <BR></script>
自定义事件的例子
<script> <BR>$("selector").bind("myClick",function(){//...}); //绑定自定义事件 <BR>$("selector").trigger("myClick"); //触发自定义事件 <BR></script>
$("selector").trigger(type[,data])
可以数组形式传递参数给回调函数
P119例:
<script> <BR>$("#btn").bind("myClick",function(event,message1,message2){ <BR>$("#test").append("<p>"+message1+message2+""); <BR>}); <BR>$("#btn").trigger("myClick", ["我的自定义","事件"]); <BR></script>
8 其他用法
$("selector").bind("type1 type2",function(){//...})
一次性绑定多个事件类型
P119值得一看的例子
<script> <BR>$(function(){ <BR>$("div").bind("mouseover mouseout",function(){ <BR>$(this).toggleClass("over"); //切换class <BR>}); <BR>}) <BR></script>
$("selector").bind("type.命名空间",function(){//...})
为多个事件添加事件命名空间,便于管理,删除命名空间后,命名空间下的事件同时删除,如:
$("div").bind("mouseover.plugin",function(){//...})
$("div").bind("click.plugin",function(){//...})
$("div").unbind(".plugin");
$("selector").trigger("type!")
"!"用来选择匹配不包含在命名空间中的type方法

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。