- Moye 开发规则
- Module: MoyeUtils 工具方法
- Class: Moye
- Class: Resource
- Class: Scene
- Class: ServiceClient
- 按钮 / Button
- 日历 / Calendar
- 城市选择器 / City
- 对话框 / Dialog
- 懒图片 / LazyImg
- 走马灯 / Marquee
- 翻页器 / Pager
- 浮层 / Popup
- 评分 / Rating
- 下拉框 / Select
- 轮播图 / Slider
- 选项卡 / Tab
- 文本框 / TextBox
- 提示 / Tip
- 表单 / Form
- 单复选框 / BoxGroup
- 开始 / get started
- 最佳实践 / best practice
- 开发指南 / introduction
- 插件 / Plugin
- 生命周期 / life cycle
- 皮肤 / skin
- 继承 / inherits
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
文本框 / TextBox
在用户输入过程中,TextBox
会发送onChange
事件,可以监听这个事件来处理用户的输入,包括获取数据、校验数据;
<label class="field-label">我是</label>
<div id="textbox1" class="ui-textbox">
<input type="text">
</div>
<div id="welcome">你好</div>
require(['moye/TextBox'], function (TextBox) {
new TextBox({
main: document.getElementById('textbox1')
})
.on('change', function () {
document.getElementById('welcome').innerText = '你好,' + this.getValue();
})
.render();
});
文本框的状态
<div class="form-row">
<div id="textbox2" class="ui-textbox ui-textbox-disabled">
<input type="text" value="禁用">
</div>
<div id="textbox3" class="ui-textbox ui-textbox-readOnly">
<input type="text" readonly="true" value="只读">
</div>
</div>
<div class="form-row">
<div id="textbox4" class="ui-textbox ui-textbox-valid">
<input type="text" value="通过校验">
</div>
<div id="textbox4" class="ui-textbox ui-textbox-invalid">
<input type="text" value="未通过校验">
</div>
</div>
自动推荐
下面这个示例,在用户输入的过程中,从百度加载相关的热门搜索词。
<div id="textbox-autocomplete" class="ui-textbox">
<input type="text" value="">
</div>
require(['moye/TextBox', 'moye/plugin/TextBoxAutoComplete'], function (TextBox, TextBoxAutoComplete) {
new TextBox({
main: document.getElementById('textbox-autocomplete'),
plugins: [{
type: 'TextBoxAutoComplete',
options: {
datasource: function (query) {
return $.ajax({
url: 'https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?json=1',
data: {wd: query},
dataType: 'jsonp',
jsonp: 'cb'
})
.then(
function (ret) {
return $.map(ret.s, function (item) {
return {
text: item,
value: item
};
});
},
function () {
return [];
}
);
},
// 定制dom
renderItem: function (data, index) {
var cls = 'acitem ' + (index % 2 ? 'even' : 'odd');
return '<div class="' + cls + '">' + data.text + '</div>';
}
}
}]
})
.render()
.on('autocomplete', function (e) {
var data = e.suggestion;
var text;
if ($.isEmptyObject(data)) {
text = $.trim(this.getValue());
}
else {
text = data.text;
}
window.open('https://www.baidu.com/s?wd=' + text);
});
});
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论