博客列表 >微信小程序官方组件展示之表单组件input源码

微信小程序官方组件展示之表单组件input源码

软件事业部
软件事业部原创
2022年08月26日 10:47:09671浏览

以下将展示微信小程序之表单组件input源码官方组件能力,组件样式仅供参考,开发者可根据自身需求定义组件样式,具体属性参数详见小程序开发文档。
功能描述:
输入框。该组件是原生组件,使用时请注意相关限制
属性说明:
WebView:

Skyline:

Bug & Tip
1.tip: confirm-type的最终表现与手机输入法本身的实现有关,部分安卓系统输入法和第三方输入法可能不支持或不完全支持
2.tip : input 组件是一个原生组件,字体是系统字体,所以无法设置 font-family
3.tip : 在 input 聚焦期间,避免使用 css 动画
4.tip : 对于将 input 封装在自定义组件中、而 form 在自定义组件外的情况, form 将不能获得这个自定义组件中 input 的值。此时需要使用自定义组件的 内置 behaviors wx://form-field
5.tip : 键盘高度发生变化,keyboardheightchange事件可能会多次触发,开发者对于相同的 height 值应该忽略掉
6.bug : 微信版本 6.3.30, focus 属性设置无效
7.bug : 微信版本 6.3.30, placeholder 在聚焦时出现重影问题

示例代码:
JAVASCRIPT:

  1. Page({
  2. data: {
  3. focus: false,
  4. inputValue: ''
  5. },
  6. bindKeyInput: function (e) {
  7. this.setData({
  8. inputValue: e.detail.value
  9. })
  10. },
  11. bindReplaceInput: function (e) {
  12. var value = e.detail.value
  13. var pos = e.detail.cursor
  14. var left
  15. if (pos !== -1) {
  16. // 光标在中间
  17. left = e.detail.value.slice(0, pos)
  18. // 计算光标的位置
  19. pos = left.replace(/11/g, '2').length
  20. }
  21. // 直接返回对象,可以对输入进行过滤处理,同时可以控制光标的位置
  22. return {
  23. value: value.replace(/11/g, '2'),
  24. cursor: pos
  25. }
  26. // 或者直接返回字符串,光标在最后边
  27. // return value.replace(/11/g,'2'),
  28. },
  29. bindHideKeyboard: function (e) {
  30. if (e.detail.value === '123') {
  31. // 收起键盘
  32. wx.hideKeyboard()
  33. }
  34. }
  35. })

WXML:

  1. <view class="page-body">
  2. <view class="page-section">
  3. <view class="weui-cells__title">可以自动聚焦的input</view>
  4. <view class="weui-cells weui-cells_after-title">
  5. <view class="weui-cell weui-cell_input">
  6. <input class="weui-input" auto-focus placeholder="将会获取焦点"/>
  7. </view>
  8. </view>
  9. </view>
  10. <view class="page-section">
  11. <view class="weui-cells__title">控制最大输入长度的input</view>
  12. <view class="weui-cells weui-cells_after-title">
  13. <view class="weui-cell weui-cell_input">
  14. <input class="weui-input" maxlength="10" placeholder="最大输入长度为10" />
  15. </view>
  16. </view>
  17. </view>
  18. <view class="page-section">
  19. <view class="weui-cells__title">实时获取输入值:{{inputValue}}</view>
  20. <view class="weui-cells weui-cells_after-title">
  21. <view class="weui-cell weui-cell_input">
  22. <input class="weui-input" maxlength="10" bindinput="bindKeyInput" placeholder="输入同步到view中"/>
  23. </view>
  24. </view>
  25. </view>
  26. <view class="page-section">
  27. <view class="weui-cells__title">控制输入的input</view>
  28. <view class="weui-cells weui-cells_after-title">
  29. <view class="weui-cell weui-cell_input">
  30. <input class="weui-input" bindinput="bindReplaceInput" placeholder="连续的两个1会变成2" />
  31. </view>
  32. </view>
  33. </view>
  34. <view class="page-section">
  35. <view class="weui-cells__title">控制键盘的input</view>
  36. <view class="weui-cells weui-cells_after-title">
  37. <view class="weui-cell weui-cell_input">
  38. <input class="weui-input" bindinput="bindHideKeyboard" placeholder="输入123自动收起键盘" />
  39. </view>
  40. </view>
  41. </view>
  42. <view class="page-section">
  43. <view class="weui-cells__title">数字输入的input</view>
  44. <view class="weui-cells weui-cells_after-title">
  45. <view class="weui-cell weui-cell_input">
  46. <input class="weui-input" type="number" placeholder="这是一个数字输入框" />
  47. </view>
  48. </view>
  49. </view>
  50. <view class="page-section">
  51. <view class="weui-cells__title">密码输入的input</view>
  52. <view class="weui-cells weui-cells_after-title">
  53. <view class="weui-cell weui-cell_input">
  54. <input class="weui-input" password type="text" placeholder="这是一个密码输入框" />
  55. </view>
  56. </view>
  57. </view>
  58. <view class="page-section">
  59. <view class="weui-cells__title">带小数点的input</view>
  60. <view class="weui-cells weui-cells_after-title">
  61. <view class="weui-cell weui-cell_input">
  62. <input class="weui-input" type="digit" placeholder="带小数点的数字键盘"/>
  63. </view>
  64. </view>
  65. </view>
  66. <view class="page-section">
  67. <view class="weui-cells__title">证件输入的input</view>
  68. <view class="weui-cells weui-cells_after-title">
  69. <view class="weui-cell weui-cell_input">
  70. <input class="weui-input" type="idcard" placeholder="证件输入键盘" />
  71. </view>
  72. </view>
  73. </view>
  74. <view class="page-section">
  75. <view class="weui-cells__title">控制占位符颜色的input</view>
  76. <view class="weui-cells weui-cells_after-title">
  77. <view class="weui-cell weui-cell_input">
  78. <input class="weui-input" placeholder-style="color:#F76260" placeholder="占位符字体是红色的" />
  79. </view>
  80. </view>
  81. </view>
  82. </view>


版权声明: 本站所有内容均由互联网收集整理、上传,如涉及版权问题,我们第一时间处理。
原文链接地址:https://developers.weixin.qq.com/miniprogram/dev/component/input.html

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议