小程序如何获取多个formId实现详解


Posted in Javascript onSeptember 20, 2019

很多人使用过form和button的多层嵌套来实现点击一次获取多个formId的目的,如下图所示,点击一次“提交”,可以获取到多个formId

小程序如何获取多个formId实现详解

但是在今年3月份,这个投机取巧的方法(算是微信的一个bug)已经被微信修复,那么再使用这个方法,所拿到的formId都是相同的了,也就不符合我们的需求了

接下来给大家介绍另一种方法:

将form和button封装成组件模拟form submit,并把这个组件做成layout级,这样可以把整个页面包括在layout里面,利用事件自动冒泡的特性,只要点击了页面任一位置,就能获取到formId

1. 新建一个组件layout,wxml、wxss、js、json代码分别如下

<form bindsubmit="formSubmit" report-submit class="layout">
 <button formType="submit" class="button" hover-class="none">
  <view class="fixed"><slot></slot></view>
 </button>
</form>
.layout {
  display: inline-block;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
  font-size: inherit;
  text-align: left;
  text-decoration: none;
  line-height: inherit;
  -webkit-tap-highlight-color: transparent;
  color: inherit;
  width: 100%;
  position: relative;
}
.layout .button{
  display: inline-block;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
  font-size: inherit;
  text-align: left;
  text-decoration: none;
  line-height: inherit;
  -webkit-tap-highlight-color: #000;
  color: inherit;
  width: 100%;
  position: relative;
}
.layout .button .fixed{
  position:relative;
  z-index: 9999;
  width: 100%;
}
.layout .button:before,.layout .button:after{
  border-width: 0;
}
Component({
 methods: {
  formSubmit: function (e) {
   let formId = e.detail.formId
   console.log(formId)
  }
 }
})
{
 "component": true
}

2. 在app.json中,将layout添加为全局组件

"usingComponents": {
  "layout": "/components/layout/index"
 }

3. 在页面中使用

<layout>
 <view class="container">
  ...
 </view>
</layout>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript实现跳转菜单的具体方法
Jul 05 Javascript
javascript数组去重方法汇总
Apr 23 Javascript
jQuery实现仿百度帖吧头部固定导航效果
Aug 07 Javascript
JavaScript编写简单的计算器
Nov 25 Javascript
jQuery中inArray方法注意事项分析
Jan 25 Javascript
JavaScript数据推送Comet技术详解
Apr 07 Javascript
JQuery手速测试小游戏实现思路详解
Sep 20 Javascript
[js高手之路]HTML标签解释成DOM节点的实现方法
Aug 31 Javascript
vue组件学习教程
Sep 09 Javascript
基于substring()和substr()的使用以及区别(实例讲解)
Dec 28 Javascript
详解小程序原生使用ES7 async/await语法
Aug 06 Javascript
Openlayers显示地理位置坐标的方法
Sep 28 Javascript
SSM+layUI 根据登录信息显示不同的页面方法
Sep 20 #Javascript
使用Layui搭建后台管理界面的操作方法
Sep 20 #Javascript
layui问题之模拟table表格中的选中按钮选中事件的方法
Sep 20 #Javascript
小程序使用watch监听数据变化的方法详解
Sep 20 #Javascript
基于layui内置模块(element常用元素的操作)
Sep 20 #Javascript
解决Layui中templet中a的onclick参数传递的问题
Sep 20 #Javascript
解决layui动态添加的元素click等事件触发不了的问题
Sep 20 #Javascript
You might like
php学习笔记(三)操作符与控制结构
2011/08/06 PHP
PHP屏蔽过滤指定关键字的方法
2014/11/03 PHP
详解Laravel服务容器的绑定与解析
2019/11/05 PHP
javascript 自定义事件初探
2009/08/21 Javascript
jQuery 渐变下拉菜单
2009/12/15 Javascript
在css加载完毕后自动判断页面是否加入css或js文件
2014/09/10 Javascript
纯JS实现本地图片预览的方法
2015/07/31 Javascript
jQuery mobile的header和footer在点击屏幕的时候消失的解决办法
2016/07/01 Javascript
超实用的javascript时间处理总结
2016/08/16 Javascript
JS实现加载时锁定HTML页面元素的方法
2017/06/24 Javascript
jQuery实现frame之间互通的方法
2017/06/26 jQuery
jquery插件canvaspercent.js实现百分比圆饼效果
2017/07/18 jQuery
微信小程序 配置顶部导航条标题颜色的实现方法
2017/09/20 Javascript
如何用RxJS实现Redux Form
2018/12/29 Javascript
详解微信小程序缓存--缓存时效性
2019/05/02 Javascript
关于layui表单中按钮自动提交的解决方法
2019/09/09 Javascript
python实现迭代法求方程组的根过程解析
2019/11/25 Javascript
JavaScript如何使用插值实现图像渐变
2020/06/28 Javascript
Python安装第三方库的3种方法
2015/06/21 Python
Python json 错误xx is not JSON serializable解决办法
2017/03/15 Python
Pycharm创建项目时如何自动添加头部信息
2019/11/14 Python
检测tensorflow是否使用gpu进行计算的方式
2020/02/03 Python
django项目中使用云片网发送短信验证码的实现
2021/01/19 Python
结合CSS3的布局新特征谈谈常见布局方法
2016/01/22 HTML / CSS
iHerb中文官网:维生素、保健品和健康产品
2018/11/01 全球购物
类的返射机制中的包及核心类
2016/09/12 面试题
优秀志愿者事迹材料
2014/02/03 职场文书
经典婚礼主持开场白
2014/03/13 职场文书
同学聚会主持词
2014/03/18 职场文书
双创工作实施方案
2014/03/26 职场文书
大学生简历自我评价2015
2015/03/03 职场文书
有关浪费资源的建议书
2015/09/14 职场文书
Python如何利用正则表达式爬取网页信息及图片
2021/04/17 Python
Java实现二分搜索树的示例代码
2022/03/17 Java/Android
海贼王十大潜力果实,路飞仅排第十,第一可毁世界(震震果实)
2022/03/18 日漫
2021年国漫热度排行前十,完美世界上榜,第四是美国动画作品
2022/03/18 国漫