用工小程序前端代码
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.
 
 
 

268 lines
7.1 KiB

<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>