时间:2021-05-26
先给大家介绍下VueJS取得URL参数
vuejs取得URL中参数的值
地址:http://localhost:3333/#/index?id=001
结果:001
console.log(this.$route.query.id)
PS:下面给大家介绍下vue自定义表单生成器可根据json参数动态生成表单效果
介绍
form-create 是一个可以通过 JSON 生成具有动态渲染、数据收集、验证和提交功能的表单生成器。并且支持生成任何 Vue 组件。结合内置17种常用表单组件和自定义组件,再复杂的表单都可以轻松搞定。
文档|github
演示项目:开源的高品质微信商城
功能
可生成任何Vue组件
自带数据验证轻
松转换为表单组件
对比 1.x
示例
通过 JSON 创建表单
通过 API 操作表单
@form-create包说明名称说明
名称 说明 @form-create/iview iview 版表单生成器 @form-create/element-ui element-ui 版表单生成器 @form-create/core form-create 核心包 @form-create/utils form-create 工具包 @form-create/data 省市区多级联动数据
使用
以element-ui版本为例介绍如何在项目中使用 form-create
安装
npm i @form-create/element-ui
挂载
全局注册
import formCreate form '@form-create/element-ui';Vue.use(formCreate);局部挂载
import formCreate form '@form-create/element-ui';export default { components:{ formCreate:formCreaet.$form() }}生成表单
<template> <form-create v-model="$f" :rule="rule" @on-submit="onSubmit"></form-create></template>export default { data () { return { //表单实例对象 $f:{}, //表单生成规则 rule:[ { type:'input', field:'goods_name', title:'商品名称' }, { type:'datePicker', field:'created_at', title:'创建时间' } ] }; }, methods:{ onSubmit(formData){ //TODO 提交表单 } }};效果
实例对象 $f
可以通过 $f 快速操作表单,例如:
自定义组件
生成
通过标签生成
{ type:'el-button', name: 'btn', props:{ type:'primary', field:'btn', loading:true }, children:['加载中']}通过模板生成
{ type:'template', name:'btn' template:'<el-button :loading="loading">{{text}}<el-button>', vm: new Vue({ data:{ loading:true, text:'加载中' } })}转换为表单组件
自定义组件转换为表单组件后,可通过$f.formData,$f.getValue,$f.setValue,$f.disabled等方法快速操作组件,达到和内置组件相同的效果
预定义
props
在自定义组件内部通过props接收一下属性
例如:
vm = Vue({ props:{ value:String, disabled:Boolean }})
input 事件
通过input事件更新组件内部的值
当组件值发生变化后,通过 input 事件更新值.例如:
vm.$emit('input',newValue);
挂载自定义组件
要生成的自定义组件必须通过Vue.component方法挂载到全局,或者通过formCreate.component方法挂载
例如:
formCreate.component('TestComponent',component);或者
Vue.component('TestComponent',component);生成
表单组件必须定义field属性
JSON
{ type:'TestComponent', value:'test', field:'testField', title:'自定义组件'}Maker
formCreate.maker.create('TestComponent','testField','自定义组件').value('test')示例
自定义计数器按钮组件,获取按钮点击数.该组件的功能和内置组件相同
formCreate.maker.template('<el-button @click="onClick" long :disabled="disabled">计数器-{{num}}</el-button>', new Vue({ props:{ //预定义 disabled:Boolean, value:Number, }, data: function () { return { num: this.value, } }, watch:{ value(n){ this.num = n; } }, methods: { onClick: function () { this.num++; //更新组件内部的值 this.$emit('input',this.num); }, },}), 'tmp', '自定义 title').value(100).props('disabled',false)完整示例
总结
以上所述是小编给大家介绍的vue自定义表单生成器可根据json参数动态生成表单,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
JQ取值方法:jquery本身也不存在取得URL参数的方法,但是已经存在插件,可以直接取得URL等参数插件连接主页:https://github.com/all
实例如下:functiongetQueStr(url,ref)//取获参数值{varstr=url.substr(url.indexOf('?')+1)
方法1:将链接当作字符串,按照链接的格式分解,然后获取对应的参数值。方法2:用正则直接匹配。关键字:parameter参数:location.href,url,
复制代码代码如下://*jQueryurlgetparametersfunction[获取URL的GET参数值]//*character_setUTF-8//*
functionrequest(paras){//获取url的参数值,不区分大小写,如无此参数,返回空字符串.varurl=location.href;varp