mui日期选择器html,MUI-城市联动,日期联动-picker(选择器)学习笔记(附最详注释)...

知识点:

城市篇

addEventListener(event,function,useCapture) :方法用于向指定元素添加事件。

addEventListener(事件名,事件需要执行的函数,布尔值)

支持:所有HTML DOM事件

(1)tap和click的区别:

两者都会在点击时触发,但是在手机WEB端,click会有 200~300 ms,所以请用tap代替click作为点击事件。

(tap有击穿现象,现在性能过剩,用click可行)

singleTap和doubleTap 分别代表单次点击和双次点击。

*poppicker组件依赖mui.picker.js/.css mui.poppicker.js/.css请务必在mui.js/css后中引用,也可统一引用 压缩版本:mui.picker.min.js

这里需要引入 mui.picker.js mui.picker.css mui.poppicker.js mui.poppicker.css

四个文件,或者这四个文件的min文件

通过new mui.PopPicker() - 初始化popPicker组件

var picker = new mui.PopPicker({ //这里注意大小写PopPicker

layer: 3 , //表示三列,即三级菜单或者联动

buttons:['取消', '确定'] //显示按钮

})

通过picker.setData - 给picker对象添加数据

setData() 支持数据格式为: 数组

picker.setData([{value:'zz',text:'智子'}]); //一列样式

picker.setData([{ //二列样式

value: '110000',

text: '北京市',

children: [{

value: "110101",

text: "东城区"

}]

}])

picker.setData([{ //三列样式

value: '110000',

text: '北京市',

children: [{

value: "110101",

text: "东城区",

children:[{

value: "111000",

text: "中关村"

}]

}]

}])

通过picker.show() - 显示picker

通过picker.show( function(getSelectedItems) { } ) 获取选中的项(数组)

PopPicker 创建实例并填充数据后,可以设定每个层级的选中项,因为 PopPicker

是支持多层级联的,所以:

(1)可通过 instance.pickers[index] 拿到指定层级的实例,

(2)然后通过setSelectedIndex()和setSelectedValue()两个方法,设定指定层级的选中项

var picker = new mui.PopPicker();

picker.setData([{

value: "first",

text: "第一项"

}, {

value: "second",

text: "第一项"

}, {

value: "third",

text: "第三项"

}, {

value: "fourth",

text: "第四项"

}, {

value: "fifth",

text: "第五项"

}])

//picker.pickers[0].setSelectedIndex(4, 2000); //4和value:''fourth''的区别

picker.pickers[0].setSelectedValue('fourth', 2000);

//这里表示默认选中第一列的第四项,时间是2000毫秒

picker.show(function(SelectedItem) { //获取选中的项(数组)注意大小写

console.log(SelectedItem);

})

.mui-picker{}可以设置选择器css样式;

.mui-picker{

background-color: #fff; //设置选择器背景为白色

}

日期篇

通过new mui.DtPicker() - 初始化DtPicker组件 //城市是new mui.PopPicker()

通过type - 设置日历初始视图模式

通过labels - 设置默认标签区域提示语

通过beginDate和endDate设置开始,结束日期

通过customData -设置时间/日期别名

通过dtPicker.show( SelectedItemsCallback ) - 显示dtPicker

var dtpicker = new mui.DtPicker({ //注意大小写

"type": "time", // 时间格式(时分)

// "type":"datetime"(年月日时分)

// "type":"date"(年月日)

// "type":"hour"(年月日时)

"labels": ['年', 'Mon', 'Day', 'Hour', 'min'],//设置默认标签区域提示语

"beginDate": new Date(2015, 04, 25),//设置开始日期

"endDate": new Date(2016, 04, 25),//设置结束日期

"customData": {

"h": [ //时

{ value: "am", text: "上午" },

{ value: "pm", text: "下午" },

],

"i":[

{value: "10", text: "10分"},

{value: "20", text: "20分"},

]

}

})

dtpicker.show(function(items) {

/* * items.value 拼合后的 value

* items.text 拼合后的 text

* items.y 年,可以通过 rs.y.vaue 和 rs.y.text 获取值和文本

* items.m 月,用法同年

* items.d 日,用法同年

* items.h 时,用法同年

* items.i 分(minutes 的第二个字母),用法同年

*/

console.log(items.d); //得到选中的年

})

4f23396553c4

QQ截图20170624231049.png

完整代码:

Hello MUI

/*.mui-poppicker-body{

background-color: white;

border: 1px solid red;

color:yellow;

}*/

.mui-picker{

background-color: white;

}

.mui-poppicker-header{

background-color: white;

}

选择城市

var picker = new mui.PopPicker({

layer: 3, //3层菜单

buttons:['取消','确定'] // 显示按钮名字

});

picker.setData([{

value: '110000',

text: '北京市',

children: [{

value: "110101",

text: "东城区",

children: [

{

value: '110111',

text:'中关村'

},

{

value: '110112',

text:'中关村2'

}

]

}],

}, {

value: '120000',

text: '天津市',

children: [

{

value: "120101",

text: "和平区"

}, {

value: "120102",

text: "河东区"

}, {

value: "120104",

text: "南开区",

children: [

{

value:'120105',

text:'地下城'

},

{

value:'120106',

text:'英雄联盟'

}

]

}

]

}])

picker.pickers[0].setSelectedIndex(1); //默认选择第1列,第2个元素(即天津市)

picker.pickers[1].setSelectedIndex(2,200,function() {}); //第2列,第三个元素(南开区)

picker.pickers[2].setSelectedIndex(1); // 第3列,(英雄联盟)

document.getElementById('aa').addEventListener('tap',function() {

picker.show(function(getSelectedItems){ //获取选中的项(数组)

console.log(getSelectedItems[0].text); //输出结果为: 天津市

})

// picker.show(function(SelectedItem) {

// console.log(SelectedItem[0].text);

// })

});

### 回答1: 据了解,苹果于2020年9月15日发布的iOS 14中,引入了一种叫做“特定地区设置”的新功能,该功能会根据用户所在的地理位置,限制部分应用的可用范围。在某些地区,该设置可能会影响mui.picker选择器在iPhone 12上的正常使用。 此外,苹果在12系列中进行了诸多技术和硬件方面的升级,这可能会导致mui.picker选择器未作出相应更改,无法与新的硬件设备进行兼容。因此,选择器使用者可能需要更新选择器的版本或等待厂商发布更新版本。 然而,需要注意的是,以上分析仅仅是对此问题的一种猜测,并未得到官方的确认。还需交流合作,共同解决此类问题。 ### 回答2: 据我们了解,最近在使用 mui.picker 选择器时发现苹果12无法正常选择的情况确实存在。这个问题主要出现在 iOS 14 系统上,尤其是在苹果12设备上。实际上,mui.picker 选择器是基于浮动层实现的,而由于 iOS 14 在设计上进行了调整,导致了选择器无法弹出。 如果使用mui.picker选择器无法选择的话,我们可以尝试使用其它替代方案,比如常规的HTML表单元素、jQuery、zepto插件等。如果非要使用mui.picker选择器的话,我们可以尝试将mui.picker插件更新至最新版,或者自行调整插件代码以适应 iOS 14 的设计变化。 还有一种方法是使用H5的input[type="date"],它的UI也很好看,适用于弹窗中使用。 总之,由于这个问题的根本原因是 iOS 14 系统在设计上出现了问题,因此我们只能通过调整插件代码或者使用其它解决方案来解决这个问题。希望我们的回答能够帮到你,如果还有其他问题,请随时让我们知道。 ### 回答3: mui.picker选择器是一款非常受欢迎的前端开发工具,它可以很好地实现数据选择的功能。然而,在苹果12上,用户在使用该工具时可能会发现无法正常选择数据的情况。 这主要是由于苹果12的操作系统更新,导致mui.picker选择器与操作系统之间的兼容性出现了问题。虽然该问题可能会给一些开发者带来困扰,但是这并不意味着mui.picker选择器已经不适用于苹果12了。实际上,开发者可以通过一些调试和优化的方法来解决这个问题。 首先,开发者可以尝试更新mui.picker选择器的版本,以确保它可以与最新的操作系统兼容。如果这种方法没有效果,那么开发者还可以尝试寻找其他类似的数据选择工具,如各种插件程序和组件库,来替代mui.picker选择器实现数据选择功能。当然,这些替代方案需要进行充分的测试和验证,以确保它们可以完美地和苹果12的操作系统兼容。 总之,对于苹果12上使用mui.picker选择器无法选择数据的问题,开发者可以通过更新版本、替代方案等多种方法来解决。毕竟,随着科技的日益发展,前端开发工具和技术也在不断更新和进化,做好更新和迭代将能更好地服务于用户。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值