Maison interface Web tutoriel HTML avalon2学习教程10事件绑定_html/css_WEB-ITnose

avalon2学习教程10事件绑定_html/css_WEB-ITnose

Jun 21, 2016 am 08:51 AM

avalon2的事件指令,比起avalon1来强大多了。

首先其内部是使用事件代理实现的,能冒泡的事件全部绑定document上。只有旧式IE的几个事件还绑定在原元素上。

其次,this直接指向vmodel,元素节点则通过e.target获取。如果要传入多个参数,需要指定事件对象,还是与原来一样使用$event

<div ms-click='@fn(111,222,$event)'>{{@ddd}}</div>
Copier après la connexion

再次,添加了一些专门针对事件回调的过滤器

  1. 对按键进行限制的过滤器esc,tab,enter,space,del,up,left,right,down

  2. 对事件方法stopPropagation, preventDefault进行简化的过滤器stop, prevent

最后,对事件回调进行缓存,防止重复生成。

事件绑定是使用ms-on-☆绑定来实现,但avalon也提供了许多快捷方式,让用户能直接以ms-eventName调用那些常用事件,如下

animationend、 blur、 change、 input、 click、 dblclick、 focus、 keydown、 keypress、 keyup、 mousedown、 mouseenter、 mouseleave、 mousemove、 mouseout、 mouseover、 mouseup、 scan、 scroll、 submit

avalon的事件绑定支持多投事件机制(同一个元素可以绑定N个同种事件,如ms-click=fn, ms-click-1=fn2, ms-click-2=fn3)

<!DOCTYPE HTML><html>    <head>        <title>ms-on</title>        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">        <meta http-equiv="X-UA-Compatible" content="IE=edge" />         <script src="./dist/avalon.js" ></script>        <script>            var vm = avalon.define({                $id: "test",                firstName: "司徒",                array: ["aaa", "bbb", "ccc"],                argsClick: function(e, a, b) {                    alert([].slice.call(arguments).join(" "))                },                loopClick: function(a, e) {                    alert(a + "  " + e.type)                },                status: "",                callback: function(e) {                    vm.status = e.type                },                field: "",                check: function(e) {                    vm.field = e.target.value + "  " + e.type                },                submit: function() {                    var data = vm.$model                    if (window.JSON) {                        setTimeout(function() {                            alert(JSON.stringify(data))                        })                    }                }            })        </script>    </head>    <body>        <fieldset ms-controller="test">            <legend>有关事件回调传参</legend>            <div ms-mouseenter="@callback" ms-mouseleave="@callback">{{@status}}<br/>                <input ms-on-input="@check"/>{{@field}}            </div>            <div ms-click="@argsClick($event, 100, @firstName)">点我</div>            <div ms-for="el in @array" >                <p ms-click="@loopClick(el, $event)">{{el}}</p>            </div>            <button ms-click="@submit" type="button">点我</button>        </fieldset>    </body></html>
Copier après la connexion

<!DOCTYPE HTML><html>    <head>        <title>ms-on</title>        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">        <meta http-equiv="X-UA-Compatible" content="IE=edge" />         <script src="./dist/avalon.js" ></script>        <script>            var count = 0            var model = avalon.define({                $id: "multi-click",                str1: "1",                str2: "2",                str3: "3",                click0: function() {                    model.str1 = "xxxxxxxxx" + (count++)                },                click1: function() {                    model.str2 = "xxxxxxxxx" + (count++)                },                click2: function() {                    model.str3 = "xxxxxxxxx" + (count++)                }            })        </script>    </head>    <body>        <fieldset>            <legend>一个元素绑定多个同种事件的回调</legend>            <div ms-controller="multi-click">                <div ms-click="@click0" ms-click-1="@click1" ms-click-2="@click2" >请点我</div>                <div>{{@str1}}</div>                <div>{{@str2}}</div>                <div>{{@str3}}</div>            </div>        </fieldset>    </body></html>
Copier après la connexion

<!DOCTYPE HTML><html>    <head>        <title>ms-on</title>        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">        <meta http-equiv="X-UA-Compatible" content="IE=edge" />         <script src="./dist/avalon.js" ></script>        <script>            avalon.define({                $id: "xxx",                fn: function() {                    console.log("11111111")                },                fn1: function() {                    console.log("2222222")                },                fn2: function() {                    console.log("3333333")                }            })        </script>    </head>    <body>        <div ms-controller="xxx"              ms-on-mouseenter-3="@fn"             ms-on-mouseenter-2="@fn1"             ms-on-mouseenter-1="@fn2"             style="width:100px;height:100px;background: red;"             >        </div>    </body></html>
Copier après la connexion

avalon已经对ms-mouseenter, ms-mouseleave进行修复,可以在 这里 与 这里 了解这两个事件。到chrome30时,所有浏览器都原生支持这两个事件。

<!DOCTYPE html> <html>    <head>        <title>ms-mouseenter, ms-mouseleave</title>        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">        <meta http-equiv="X-UA-Compatible" content="IE=edge" />         <script src="./dist/avalon.js"></script>        <script>            avalon.define({                $id: "test",                fn1: function(e) {                    console.log(e.type)                    console.log(e.target)                },                fn2: function(e) {                    console.log(e.type)                    console.log(e.target)                }            })        </script>    </head>    <body ms-controller="test">        <div ms-mouseenter="@fn1" ms-mouseleave="@fn2" style="background: red;width:200px;height: 200px;padding:20px;">            <div style="background: blue;width:160px;height: 160px;margin:20px;"></div>        </div>    </body></html>
Copier après la connexion

最后是mousewheel事件的修改,主要问题是出现firefox上,它死活也不愿意支持mousewheel,在avalon里是用DOMMouseScroll或wheel实现模拟的。我们在事件对象通过wheelDelta属性是否为正数判定它在向上滚动。

<!DOCTYPE html><html>    <head>        <title>ms-on-mousewheel</title>        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">        <meta http-equiv="X-UA-Compatible" content="IE=edge" />         <script src="./dist/avalon.js"></script>        <script>            var vm = avalon.define({                $id: "test",                text: "",                callback: function(e) {                    vm.text = e.wheelDelta + "  " + e.type                }            })        </script>    </head>    <body ms-controller="test">        <div ms-on-mousewheel="@callback" id="aaa" style="background: red;width:200px;height: 200px;">            {{@text}}        </div>    </body></html>
Copier après la connexion

此外avalon还对input,animationend事件进行修复,大家也可以直接用avalon.bind, avalon.fn.bind来绑定这些事件。但建议都用ms-on绑定来处理。

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quel est le but du & lt; Progress & gt; élément? Quel est le but du & lt; Progress & gt; élément? Mar 21, 2025 pm 12:34 PM

L'article traite du HTML & lt; Progress & GT; élément, son but, son style et ses différences par rapport au & lt; mètre & gt; élément. L'objectif principal est de l'utiliser & lt; Progress & gt; pour l'achèvement des tâches et & lt; mètre & gt; pour stati

Quel est le but du & lt; datalist & gt; élément? Quel est le but du & lt; datalist & gt; élément? Mar 21, 2025 pm 12:33 PM

L'article traite du HTML & lt; Datalist & GT; élément, qui améliore les formulaires en fournissant des suggestions de saisie semi-automatique, en améliorant l'expérience utilisateur et en réduisant les erreurs. COMMANDE COMPRES: 159

Quel est le but du & lt; mètre & gt; élément? Quel est le but du & lt; mètre & gt; élément? Mar 21, 2025 pm 12:35 PM

L'article traite du HTML & lt; mètre & gt; élément, utilisé pour afficher des valeurs scalaires ou fractionnaires dans une plage, et ses applications courantes dans le développement Web. Il différencie & lt; mètre & gt; De & lt; Progress & gt; et ex

Quelle est la balise Meta de la fenêtre? Pourquoi est-ce important pour une conception réactive? Quelle est la balise Meta de la fenêtre? Pourquoi est-ce important pour une conception réactive? Mar 20, 2025 pm 05:56 PM

L'article traite de la balise Meta de la fenêtre, essentielle pour la conception Web réactive sur les appareils mobiles. Il explique comment une utilisation appropriée garantit une mise à l'échelle optimale du contenu et une interaction utilisateur, tandis que la mauvaise utilisation peut entraîner des problèmes de conception et d'accessibilité.

Quel est le but du & lt; iframe & gt; étiqueter? Quelles sont les considérations de sécurité lorsque vous l'utilisez? Quel est le but du & lt; iframe & gt; étiqueter? Quelles sont les considérations de sécurité lorsque vous l'utilisez? Mar 20, 2025 pm 06:05 PM

L'article traite du & lt; iframe & gt; L'objectif de Tag dans l'intégration du contenu externe dans les pages Web, ses utilisations courantes, ses risques de sécurité et ses alternatives telles que les balises d'objet et les API.

HTML est-il facile à apprendre pour les débutants? HTML est-il facile à apprendre pour les débutants? Apr 07, 2025 am 12:11 AM

HTML convient aux débutants car il est simple et facile à apprendre et peut rapidement voir les résultats. 1) La courbe d'apprentissage de HTML est fluide et facile à démarrer. 2) Il suffit de maîtriser les balises de base pour commencer à créer des pages Web. 3) Flexibilité élevée et peut être utilisée en combinaison avec CSS et JavaScript. 4) Les ressources d'apprentissage riches et les outils modernes soutiennent le processus d'apprentissage.

Les rôles de HTML, CSS et JavaScript: responsabilités de base Les rôles de HTML, CSS et JavaScript: responsabilités de base Apr 08, 2025 pm 07:05 PM

HTML définit la structure Web, CSS est responsable du style et de la mise en page, et JavaScript donne une interaction dynamique. Les trois exercent leurs fonctions dans le développement Web et construisent conjointement un site Web coloré.

Quel est un exemple d'une balise de départ dans HTML? Quel est un exemple d'une balise de départ dans HTML? Apr 06, 2025 am 12:04 AM

Anexampleofastartingtaginhtmlis, qui abinginsaparagraph.startingtagsaressentialtinhtmlastheyinitiateelements, définit les éventualités, et la faculté de réduction des pages et de la construction de la création.

See all articles