在mootools中转换jquery代码
Convert code of jquery in mootools
请帮助将jquery代码转换为mootools。
我没有找到清晰的mootools插件,如jquery http://jsbin.com/sejuquta/528/edit.
jQuery(function($) {
function tog(v){return v?'addClass':'removeClass';}
$(document).on('input', '.clearable', function(){
$(this)[tog(this.value)]('x');
}).on('mousemove', '.x', function( e ){
$(this)[tog(this.offsetWidth-18 < e.clientX-this.getBoundingClientRect().left)]('onX');
}).on('click', '.onX', function(){
$(this).removeClass('x onX').val('');
});
});
我试图将此代码重写为mootools,但我没有成功(http://jsbin.com/wofaripi/1/edit)。
window.addEvent("domready", function() {
function tog(v){return v?'addClass':'removeClass';}
$$('input[type=text]').addEvent('input', '.clearable', function(){
this[tog(this.value)]('x');
}).addEvent('mousemove', '.x', function( e ){
this[tog(this.offsetWidth-18 < e.clientX-this.getBoundingClientRect().left)]('onX');
}).addEvent('click', '.onX', function(){
this.removeClass('x onX').set('value', '');
});
});
谢谢。
你很好地完成了转换。
一些注意事项:
#1 - MooTools中的委托看起来有点不同,你可以在这里阅读它,但它应该看起来像:
$(document.body).addEvent('input:relay(input.clearable)', function(){
#2 -我会删除tog
"东西"。MooTools有一个带有第二个函数参数"force"的toggleClass方法,它可以做到这一点,并且更易于阅读。
#3 - MooTools中的添加/删除类方法允许添加以空格分隔的类,但这没有文档记录,也没有官方支持。所以我用this.removeClass('x').removeClass('onX')
代替this.removeClass('x onX');
,这也可以,非正式地。
所以,代码:
window.addEvent("domready", function () {
$(document.body).addEvents({
'input:relay(input.clearable)': function () {
this.toggleClass('x', this.value);
},
'mousemove:relay(.x)': function (e) {
this.toggleClass('onX', this.offsetWidth - 18 < e.clientX - this.getBoundingClientRect().left);
},
'click:relay(.onX)': function () {
this.removeClass('x').removeClass('onX').set('value', '');
}
});
});
jsFiddle: http://jsfiddle.net/92McL/
相关文章:
- 如何动态插入jquery代码
- 如何在php变量中嵌入JQuery代码
- 将 jQuery 代码添加到 Index.aspx 页面
- jquery代码在Mozilla中有效,但在其他浏览器上无效
- Jquery:代码在rails中的页面加载时未执行
- 点击facebook像素跟踪注册(JS/JQUERY代码)
- 我的jquery代码不起作用.为什么?
- 将javascript代码转换为jquery代码时出错
- 在CodeIgniter视图中将Javascript或jQuery代码作为PHP文件编写可以吗
- 按键时停止jquery代码
- 在Grails中的gsp中执行jquery代码
- 这个jquery代码是如何工作的
- 如何在加载角度函数后运行jQuery代码
- 如何使用Javascript或jQuery代码调用mousemove
- 如何使用我的Jquery代码创建委托事件侦听器
- 为什么jQuery代码段在没有IFrame的情况下可以工作,而在有IFrame时却不能工作
- 将JQuery代码转换为等效的JavaScript代码
- JQuery代码语法问题?(“不允许内联控制结构”)
- 使用一个 jquery 代码关闭多个模态
- 如何简化动画jQuery代码