Blame view

pages/component/form/form.vue 2.58 KB
4b045f7c   刘淇   江阴初始化项目
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
  <template>
  	<view>
  		<page-head title="form"></page-head>
  		<view class="uni-padding-wrap uni-common-mt">
  			<form @submit="formSubmit" @reset="formReset">
  				<view class="uni-form-item uni-column">
  					<view class="title">姓名</view>
  					<input class="uni-input" name="nickname" placeholder="请输入姓名" />
  				</view>
  				<view class="uni-form-item uni-column">
  					<view class="title">性别</view>
  					<radio-group name="gender">
  						<label>
  							<radio value="男" /><text>男</text>
  						</label>
  						<label>
  							<radio value="女" /><text>女</text>
  						</label>
  					</radio-group>
  				</view>
  				<view class="uni-form-item uni-column">
  					<view class="title">爱好</view>
  					<checkbox-group name="loves">
  						<label>
  							<checkbox value="读书" /><text>读书</text>
  						</label>
  						<label>
  							<checkbox value="写字" /><text>写字</text>
  						</label>
  					</checkbox-group>
  				</view>
  				<view class="uni-form-item uni-column">
  					<view class="title">年龄</view>
  					<slider value="20" name="age" show-value></slider>
  				</view>
  				<view class="uni-form-item uni-column">
  					<view class="title">保留选项</view>
  					<view>
  						<switch name="switch" />
  					</view>
  				</view>
  				<view class="uni-btn-v">
  					<button form-type="submit">Submit</button>
  					<button type="default" form-type="reset">Reset</button>
  				</view>
  			</form>
  		</view>
  	</view>
  </template>
  <script>
  	import graceChecker from "../../../common/graceChecker.js"
  	export default {
  		data() {
  			return {
  			}
  		},
  		methods: {
  			formSubmit: function(e) {
  				console.log('form发生了submit事件,携带数据为:' + JSON.stringify(e.detail.value))
                  //定义表单规则
                  var rule = [
                      {name:"nickname", checkType : "string", checkRule:"1,3",  errorMsg:"姓名应为1-3个字符"},
                      {name:"gender", checkType : "in", checkRule:"男,女",  errorMsg:"请选择性别"},
                      {name:"loves", checkType : "notnull", checkRule:"",  errorMsg:"请选择爱好"}
                  ];
                  //进行表单检查
                  var formData = e.detail.value;
                  var checkRes = graceChecker.check(formData, rule);
                  if(checkRes){
                      uni.showToast({title:"验证通过!", icon:"none"});
                  }else{
                      uni.showToast({ title: graceChecker.error, icon: "none" });
                  }
  			},
  			formReset: function(e) {
  				console.log('清空数据')
  			}
  		}
  	}
  </script>
  
  <style>
  	.uni-form-item .title {
  		padding: 20rpx 0;
  	}
  </style>