一、事件
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方法

Zu den Hauptanwendungen von JavaScript in der Webentwicklung gehören die Interaktion der Clients, die Formüberprüfung und die asynchrone Kommunikation. 1) Dynamisches Inhaltsaktualisierung und Benutzerinteraktion durch DOM -Operationen; 2) Die Kundenüberprüfung erfolgt vor dem Einreichung von Daten, um die Benutzererfahrung zu verbessern. 3) Die Aktualisierung der Kommunikation mit dem Server wird durch AJAX -Technologie erreicht.

Es ist für Entwickler wichtig, zu verstehen, wie die JavaScript -Engine intern funktioniert, da sie effizientere Code schreibt und Leistungs Engpässe und Optimierungsstrategien verstehen kann. 1) Der Workflow der Engine umfasst drei Phasen: Parsen, Kompilieren und Ausführung; 2) Während des Ausführungsprozesses führt die Engine dynamische Optimierung durch, wie z. B. Inline -Cache und versteckte Klassen. 3) Zu Best Practices gehören die Vermeidung globaler Variablen, die Optimierung von Schleifen, die Verwendung von const und lass und die Vermeidung übermäßiger Verwendung von Schließungen.

Python eignet sich besser für Anfänger mit einer reibungslosen Lernkurve und einer kurzen Syntax. JavaScript ist für die Front-End-Entwicklung mit einer steilen Lernkurve und einer flexiblen Syntax geeignet. 1. Python-Syntax ist intuitiv und für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet. 2. JavaScript ist flexibel und in Front-End- und serverseitiger Programmierung weit verbreitet.

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Die Verschiebung von C/C zu JavaScript erfordert die Anpassung an dynamische Typisierung, Müllsammlung und asynchrone Programmierung. 1) C/C ist eine statisch typisierte Sprache, die eine manuelle Speicherverwaltung erfordert, während JavaScript dynamisch eingegeben und die Müllsammlung automatisch verarbeitet wird. 2) C/C muss in den Maschinencode kompiliert werden, während JavaScript eine interpretierte Sprache ist. 3) JavaScript führt Konzepte wie Verschlüsse, Prototypketten und Versprechen ein, die die Flexibilität und asynchrone Programmierfunktionen verbessern.

Unterschiedliche JavaScript -Motoren haben unterschiedliche Auswirkungen beim Analysieren und Ausführen von JavaScript -Code, da sich die Implementierungsprinzipien und Optimierungsstrategien jeder Engine unterscheiden. 1. Lexikalanalyse: Quellcode in die lexikalische Einheit umwandeln. 2. Grammatikanalyse: Erzeugen Sie einen abstrakten Syntaxbaum. 3. Optimierung und Kompilierung: Generieren Sie den Maschinencode über den JIT -Compiler. 4. Führen Sie aus: Führen Sie den Maschinencode aus. V8 Engine optimiert durch sofortige Kompilierung und versteckte Klasse.

Zu den Anwendungen von JavaScript in der realen Welt gehören die serverseitige Programmierung, die Entwicklung mobiler Anwendungen und das Internet der Dinge. Die serverseitige Programmierung wird über node.js realisiert, die für die hohe gleichzeitige Anfrageverarbeitung geeignet sind. 2. Die Entwicklung der mobilen Anwendungen erfolgt durch reaktnative und unterstützt die plattformübergreifende Bereitstellung. 3.. Wird für die Steuerung von IoT-Geräten über die Johnny-Five-Bibliothek verwendet, geeignet für Hardware-Interaktion.

Ich habe eine funktionale SaaS-Anwendung mit mehreren Mandanten (eine EdTech-App) mit Ihrem täglichen Tech-Tool erstellt und Sie können dasselbe tun. Was ist eine SaaS-Anwendung mit mehreren Mietern? Mit Multi-Tenant-SaaS-Anwendungen können Sie mehrere Kunden aus einem Sing bedienen


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

Dreamweaver Mac
Visuelle Webentwicklungstools