用工小程序前端代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

170 lines
4.5 KiB

8 months ago
  1. <template>
  2. <view>
  3. <u--form labelPosition="left" :model="form" :rules="rules" ref="uForm" labelWidth="80">
  4. <view class="se-p-20">
  5. <view class="se-p-20 se-bgc-white se-br-10 se-fs-20">
  6. <u-form-item label="姓名" prop="name">
  7. <u--input v-model="form.name" class="se-bgc-f5" placeholder="请输入姓名名称"></u--input>
  8. </u-form-item>
  9. <u-form-item label="密码" prop="password">
  10. <u--input v-model="form.password" class="se-bgc-f5" placeholder="请输入您的密码"></u--input>
  11. </u-form-item>
  12. <u-form-item label="联系电话" prop="mobile">
  13. <u--input v-model="form.mobile" class="se-bgc-f5" placeholder="请输入联系方式"></u--input>
  14. </u-form-item>
  15. <u-form-item label="公司名称" prop="company">
  16. <u--input v-model="form.company" class="se-bgc-f5" placeholder="请输入公司名称"></u--input>
  17. </u-form-item>
  18. <u-form-item label="公司地址" prop="address">
  19. <u--input v-model="form.address" class="se-bgc-f5" placeholder="请输入公司地址"></u--input>
  20. </u-form-item>
  21. <u-form-item label="行业" prop="industry">
  22. <u--input v-model="form.industry" class="se-bgc-f5" placeholder="请输入行业"></u--input>
  23. </u-form-item>
  24. </view>
  25. </view>
  26. <view class="se-p-20">
  27. <view class="se-px-20 se-pb-20 se-bgc-white se-br-10 se-fs-20">
  28. <u-form-item prop="file" labelWidth="2">
  29. <view class="se-flex se-flex-v-sa">
  30. <view class="se-py-20 se-w-p-100 se-flex">
  31. <view class="line-orange"></view>
  32. <view class="se-ml-10">
  33. 营业执照上传
  34. </view>
  35. </view>
  36. <view class="se-py-20 se-w-p-100">
  37. <u-upload :fileList="fileList" @afterRead="afterRead" @delete="deletePic" name="1"
  38. multiple :maxCount="10"></u-upload>
  39. </view>
  40. </view>
  41. </u-form-item>
  42. </view>
  43. </view>
  44. <view class="se-px-20 se-pt-20">
  45. <view class="se-px-20 se-pb-80 se-fs-20 se-flex">
  46. <view @click="submit"
  47. class="se-mx-10 se-flex-1 se-br-40 se-flex-h-c se-h-60 se-lh-60 se-ta-c se-fs-28 se-c-white se-bgc-orange">
  48. <text>申请审核</text>
  49. </view>
  50. <view
  51. class="se-mx-10 se-flex-1 se-b se-br-40 se-flex-h-c se-h-60 se-lh-60 se-ta-c se-fs-28 se-c-66 se-bgc-f5">
  52. <text>联系我们</text>
  53. </view>
  54. </view>
  55. </view>
  56. </u--form>
  57. </view>
  58. </template>
  59. <script>
  60. export default{
  61. data(){
  62. return{
  63. fileList: [],
  64. form: {
  65. name: '',
  66. password: '',
  67. mobile: '',
  68. company:'',
  69. address:'',
  70. industry:'',
  71. file: ''
  72. },
  73. rules: {
  74. name: [{
  75. type: 'string',
  76. required: true,
  77. message: '请输入姓名名称',
  78. trigger: ['blur', 'change']
  79. }],
  80. password: [{
  81. type: 'string',
  82. required: true,
  83. message: '请输入您的密码',
  84. trigger: ['blur', 'change']
  85. }],
  86. mobile: [
  87. {
  88. required: true,
  89. message: '请输入手机号',
  90. trigger: ['change','blur'],
  91. },
  92. {
  93. validator: (rule, value, callback) => {
  94. return uni.$u.test.mobile(value);
  95. },
  96. message: '手机号码不正确',
  97. trigger: ['change','blur'],
  98. },
  99. ],
  100. company: [{
  101. type: 'string',
  102. required: true,
  103. message: '请输入公司名称',
  104. trigger: ['blur', 'change']
  105. }],
  106. address: [{
  107. type: 'string',
  108. required: true,
  109. message: '请输入公司地址',
  110. trigger: ['blur', 'change']
  111. }],
  112. industry: [{
  113. type: 'string',
  114. required: true,
  115. message: '请输入行业',
  116. trigger: ['blur', 'change']
  117. }],
  118. file: [{
  119. type: 'string',
  120. required: true,
  121. message: '请选择营业执照',
  122. trigger: ['blur', 'change']
  123. }]
  124. },
  125. }
  126. },
  127. watch: {
  128. fileList(newValue, oldValue) {
  129. if (newValue.length > 0) {
  130. this.form.file = '有'
  131. } else {
  132. this.form.file = ''
  133. }
  134. }
  135. },
  136. onReady() {
  137. this.$refs.uForm.setRules(this.rules)
  138. },
  139. methods: {
  140. submit() {
  141. this.$refs.uForm.validate().then(res => {
  142. uni.$u.toast('校验通过')
  143. }).catch(errors => {
  144. // uni.$u.toast('校验失败')
  145. })
  146. },
  147. deletePic(event) {
  148. this.fileList.splice(e.index, 1)
  149. },
  150. async afterRead(e) {
  151. let self = this
  152. e.file.forEach(file => {
  153. self.$Oss.ossUpload(file.url).then(url => {
  154. self.fileList.push({
  155. url
  156. })
  157. })
  158. })
  159. }
  160. }
  161. }
  162. </script>
  163. <style lang="scss" scoped>
  164. .line-orange {
  165. width: 8rpx;
  166. height: 32rpx;
  167. background: #ff7a31;
  168. border-radius: 4rpx;
  169. }
  170. </style>