|
|
- <template>
- <view>
- <u--form labelPosition="left" :model="form" :rules="rules" ref="uForm" labelWidth="80">
- <view class="se-p-20">
- <view class="se-p-20 se-bgc-white se-br-10 se-fs-20">
- <u-form-item label="姓名" prop="name">
- <u--input v-model="form.name" class="se-bgc-f5" placeholder="请输入姓名名称"></u--input>
- </u-form-item>
- <u-form-item label="密码" prop="password">
- <u--input v-model="form.password" class="se-bgc-f5" placeholder="请输入您的密码"></u--input>
- </u-form-item>
- <u-form-item label="联系电话" prop="mobile">
- <u--input v-model="form.mobile" class="se-bgc-f5" placeholder="请输入联系方式"></u--input>
- </u-form-item>
- <u-form-item label="年龄" prop="age">
- <u--input v-model="form.age" class="se-bgc-f5" placeholder="请输入年龄"></u--input>
- </u-form-item>
- <u-form-item label="性别" prop="sex" @click="handleSexChange">
- <u--input @click="handleSexChange" readonly v-model="form.sex" placeholder="请选择性别"
- border="none"></u--input>
- <u-icon @click="handleSexChange" slot="right" name="arrow-right"></u-icon>
- </u-form-item>
- <u-form-item label="工种" prop="type" @click="handleTypeChange">
- <u--input @click="handleTypeChange" v-model="form.type" readonly placeholder="请选择工种"
- border="none"></u--input>
- <u-icon @click="handleTypeChange" slot="right" name="arrow-right"></u-icon>
- </u-form-item>
- <u-form-item label="薪资待遇" prop="salary">
- <view class="se-flex se-flex-h-c">
- <u--input v-model="form.salaryMin" class="se-w-200" placeholder="最小值"></u--input>
- <text class="se-mx-10">~</text>
- <u--input v-model="form.salaryMax" class="se-w-200" placeholder="最大值"></u--input>
- </view>
- </u-form-item>
- <u-form-item label="个人介绍" prop="introduce">
- <u--textarea v-model="form.introduce" count class="se-bgc-f5"
- placeholder="请选择个人介绍"></u--textarea>
- </u-form-item>
- </view>
- </view>
- <view class="se-p-20">
- <view class="se-px-20 se-pb-20 se-bgc-white se-br-10 se-fs-20">
- <u-form-item prop="file" labelWidth="2">
- <view class="se-flex se-flex-v-sa">
- <view class="se-py-20 se-w-p-100 se-flex">
- <view class="line-orange"></view>
- <view class="se-ml-10">
- 身份证上传(正反面)
- </view>
- </view>
- <view class="se-py-20 se-w-p-100">
- <u-upload :fileList="fileList" @afterRead="afterRead" @delete="deletePic" name="1"
- multiple :maxCount="10"></u-upload>
- </view>
- </view>
- </u-form-item>
- </view>
- </view>
- <view class="se-px-20 se-pt-20">
- <view class="se-px-20 se-pb-80 se-fs-20 se-flex">
- <view @click="submit"
- 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">
- <text>申请审核</text>
- </view>
- <view
- 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">
- <text>联系我们</text>
- </view>
- </view>
- </view>
- </u--form>
- <!-- 性别 -->
- <u-action-sheet :show="showSex" :actions="sexList" title="请选择性别" @close="showSex = false" @select="sexSelect">
- </u-action-sheet>
- <!-- 种类 -->
- <u-action-sheet :show="showType" :actions="typeList" title="请选择种类" @close="showType = false"
- @select="typeSelect">
- </u-action-sheet>
- </view>
- </template>
-
- <script>
- export default {
- data() {
- return {
- showSex: false,
- sexList: [{
- name: '男',
- },
- {
- name: '女',
- }
- ],
- showType: false,
- typeList: [{
- name: '铁匠',
- },
- {
- name: '水泥搬运',
- }
- ],
- fileList: [],
- form: {
- name: '',
- password: '',
- mobile: '',
- age: '',
- sex: '',
- type: '',
- salary:'',
- salaryMin: '',
- salaryMax: '',
- introduce: '',
- file: ''
- },
- rules: {
- name: [{
- type: 'string',
- required: true,
- message: '请输入姓名名称',
- trigger: ['blur', 'change']
- }],
- password: [{
- type: 'string',
- required: true,
- message: '请输入您的密码',
- trigger: ['blur', 'change']
- }],
- mobile: [
- {
- required: true,
- message: '请输入手机号',
- trigger: ['change','blur'],
- },
- {
- validator: (rule, value, callback) => {
- return uni.$u.test.mobile(value);
- },
- message: '手机号码不正确',
- trigger: ['change','blur'],
- },
- ],
- age: [
- {
- required: true,
- message: '请输入年龄',
- trigger: ['change','blur'],
- },
- {
- type: 'string',
- required: true,
- min: 18,
- max: 65,
- message: '请输入正确年龄',
- trigger: ['blur', 'change']
- }],
- sex: [{
- type: 'string',
- max: 1,
- required: true,
- message: '请选择性别',
- trigger: ['blur', 'change']
- }],
- salary: [{
- type: 'string',
- required: true,
- message: '请输入薪资待遇',
- trigger: ['blur', 'change']
- }],
- introduce: [{
- type: 'string',
- required: true,
- message: '请输入个人简介',
- trigger: ['blur', 'change']
- }],
- file: [{
- type: 'string',
- required: true,
- message: '请选择身份证',
- trigger: ['blur', 'change']
- }]
- },
- }
- },
- watch: {
- 'form.salaryMin': {
- handler(newVal, oldVal) {
- if (!uni.$u.test.isEmpty(newVal) && !uni.$u.test.isEmpty(this.form.salaryMax)) {
- this.form.salary = '有'
- } else {
- this.form.salary = ''
- }
- },
- immediate: true
- },
- 'form.salaryMax': {
- handler(newVal, oldVal) {
- if (!uni.$u.test.isEmpty(newVal) && !uni.$u.test.isEmpty(this.form.salaryMin)) {
- this.form.salary = '有'
- } else {
- this.form.salary = ''
- }
- },
- immediate: true
- },
- fileList(newValue, oldValue) {
- if (newValue.length > 0) {
- this.form.file = '有'
- } else {
- this.form.file = ''
- }
- }
- },
- methods: {
- handleSexChange() {
- this.showSex = true
- },
- sexSelect(e) {
- this.form.sex = e.name
- this.$refs.uForm.validateField('sex')
- },
- handleTypeChange() {
- this.showType = true
- },
- typeSelect(e) {
- this.form.type = e.name
- this.$refs.uForm.validateField('type')
- },
- submit() {
- this.$refs.uForm.validate().then(res => {
- uni.$u.toast('校验通过')
- }).catch(errors => {
- // uni.$u.toast('校验失败')
- })
- },
- deletePic(event) {
- this.fileList.splice(e.index, 1)
- },
- async afterRead(e) {
- let self = this
- e.file.forEach(file => {
- self.$Oss.ossUpload(file.url).then(url => {
- self.fileList.push({
- url
- })
- })
- })
- }
- },
- onReady() {
- //如果需要兼容微信小程序,并且校验规则中含有方法等,只能通过setRules方法设置规则。
- this.$refs.uForm.setRules(this.rules)
- },
- }
- </script>
-
- <style lang="scss" scoped>
- page {
- background-color: #f5f5f5 !important;
- }
-
- .line-orange {
- width: 8rpx;
- height: 32rpx;
- background: #ff7a31;
- border-radius: 4rpx;
- }
- </style>
|