创新互联百度小程序教程:form表单

  • form 表单
    • 属性说明
      • report-type 有效值
      • report-type 为 subscribe 时,event.detail.formId 说明
      • report-type 为 subscribe 时,status 和 message 具体值
    • 示例
      • 代码示例 1:普通表单
      • 代码示例 2:模板类型表单

    form 表单

    解释:表单,将 form 组件内用户输入 / 选择的提交。当

    表单中 form-type 为 submit 时,点击的
  •  
     
     
    1. Page({
    2. formSubmit(e) {
    3. // 此时 formId 为 'BD0001-formId'(非真实数据)
    4. swan.showModal({
    5. title: 'template-id 为 string',
    6. content: e.detail.formId
    7. });
    8. }
    9. });

    2. 当 template-id 为 Array 时(基础库 3.170.1 开始支持),event.detail 的 formId 为 Object ,其中对象的 key 为 template-id ,value 为其对应的 formId 。举例如下

    • SWAN
    • JS
     
     
     
     
     
     
    1. Page({
    2. data: {
    3. templateId: ['BD0001', 'BD0002']
    4. },
    5. formSubmit(e) {
    6. // 此时 formId 为 {'BD0001': 'BD0001-formId', 'BD0002': 'BD0002-formId'}(非真实数据)
    7. swan.showModal({
    8. title: 'template-id 为 Array',
    9. content: JSON.stringify(e.detail.formId)
    10. });
    11. }
    12. });

    如果 Array 中的 template-id 超过三个,返回的 formId 为空字符串,举例如下:

    • SWAN
    • JS
     
     
     
     
     
     
    1. Page({
    2. data: {
    3. templateId: ['BD0001', 'BD0002', 'BD0003', 'BD0004']
    4. },
    5. formSubmit(e) {
    6. // 此时 formId 为 ''
    7. swan.showModal({
    8. title: 'template-id 超过三个',
    9. content: e.detail.formId
    10. });
    11. }
    12. });

    如果 Array 中有重复的 template-id ,重复的 template-id 对应的 formId 只返回一次,举例如下:

    • SWAN
    • JS
     
     
     
     
     
     
    1. Page({
    2. data: {
    3. templateId: ['BD0001', 'BD0001', 'BD0002']
    4. },
    5. formSubmit(e) {
    6. // 此时 formId 为 {'BD0001': 'BD0001-formId', 'BD0002': 'BD0002-formId'}(非真实数据)
    7. swan.showModal({
    8. title: '有重复的 template-id',
    9. content: JSON.stringify(e.detail.formId)
    10. });
    11. }
    12. });

    注意:在提交 form 表单时,将会弹出模板消息授权弹窗,用户授权后才能在 event.detail 中获取被授权模板消息的 formId 。

    report-type 为 subscribe 时,status 和 message 具体值

    status 为 Number 类型,message 为 String 类型,当用户永久拒绝授权的时候,建议开发者不要再展示订阅消息授权面板入口。

    status message
    500101用户永久拒绝授权
    500102用户单次拒绝授权
    500103用户取消授权
    500104请求模板内容失败
    500105请求 formId 失败

    示例

    跳转编辑工具

    在开发者工具中打开

    在 WEB IDE 中打开

    扫码体验

    代码示例

    请使用百度APP扫码

    代码示例 1:普通表单

    • SWAN
    • JS
     
     
     
    1. bindreset="formReset">
    2. 开关选择器
    3. 开关
    4. 单项选择器
    5. 单选项一
    6. 单选项二
    7. 多项选择器
    8. 多选项一
    9. 多选项二
    10. 多选项三
    11. 滑块选择器
    12. 输入框
    13. 提交表单
     
     
     
    1. Page({
    2. formSubmit(e) {
    3. console.log('form发生了submit事件,携带数据为:', e.detail.value);
    4. swan.showModal({
    5. content: '数据:' + JSON.stringify(e.detail.value),
    6. confirmText: '确定'
    7. });
    8. },
    9. formReset(e) {
    10. console.log('form表单发生了', e.type);
    11. }
    12. });

    代码示例 2:模板类型表单

    在开发者工具中打开

    在开发者工具中打开

    在 WEB IDE 中打开

    • SWAN
    • JS
     
     
     
    1. report-submit
    2. report-type="subscribe"
    3. template-id="BD0003"
    4. subscribe-id="8026"
    5. bindsubmit="reportFormSubmit"
    6. bindreset="reportFormReset">
    7. report-type为subscribe
    8. report-submit
    9. report-type="default"
    10. bindsubmit="reportFormSubmit"
    11. bindreset="reportFormReset">
    12. report-type为default
     
     
     
    1. Page({
    2. onLoad() {
    3. swan.showToast({
    4. title: '此组件需要登录态,请先点击下方的按钮登录',
    5. icon: 'none'
    6. })
    7. },
    8. login(e) {
    9. // 此组件需要在登陆态下使用
    10. console.log('登录信息:', e);
    11. if (e.detail.errCode === '10004') {
    12. swan.showToast({
    13. title: '用户未登录',
    14. icon: 'none'
    15. });
    16. return;
    17. }
    18. swan.showToast({
    19. title: '用户登录成功',
    20. icon: 'none'
    21. });
    22. },
    23. formSubmit(e) {
    24. swan.showModal({
    25. title: '表单数据',
    26. content: JSON.stringify(e.detail.message) + '/' +JSON.stringify(e.detail.status),
    27. confirmText: '确定',
    28. showCancel: false
    29. });
    30. }
    31. });

    当前文章:创新互联百度小程序教程:form表单
    转载来于:http://www.mswzjz.cn/qtweb/news5/7105.html

    攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能