apply.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. <template>
  2. <view class="personal">
  3. <view class="">
  4. <text class="title">添加求职意向</text>
  5. <view class="titleb">不同的求职期望,推荐啊的职位也会不同。</view>
  6. </view>
  7. <view class="body-input u-flex-col u-row-center" @click="birthdayBtn">
  8. <text class="input-title">求职时间</text>
  9. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  10. placeholder="请选择您的求职时间" border placeholderClass='input-style' suffixIcon="arrow-right"
  11. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="from.birthday"></u--input>
  12. </view>
  13. <view class="body-input u-flex-col u-row-center" @click="cityShow = true">
  14. <text class="input-title">期望城市</text>
  15. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  16. placeholder="请选择您的期望城市" border placeholderClass='input-style' suffixIcon="arrow-right"
  17. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="from.birthday"></u--input>
  18. </view>
  19. <view class="body-input u-flex-col u-row-center" @click="birthdayBtn">
  20. <text class="input-title">期望薪资</text>
  21. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  22. placeholder="请选择您的期望薪资" border placeholderClass='input-style' suffixIcon="arrow-right"
  23. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="from.birthday"></u--input>
  24. </view>
  25. <view class="body-input u-flex-col u-row-center" @click="birthdayBtn">
  26. <text class="input-title">当前行业</text>
  27. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  28. placeholder="请选择您的当前行业" border placeholderClass='input-style' suffixIcon="arrow-right"
  29. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="from.birthday"></u--input>
  30. </view>
  31. <view class="body-input u-flex-col u-row-center" @click="birthdayBtn">
  32. <text class="input-title">期望行业</text>
  33. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  34. placeholder="请选择您的期望行业" border placeholderClass='input-style' suffixIcon="arrow-right"
  35. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="from.birthday"></u--input>
  36. </view>
  37. <view class="body-input u-flex-col u-row-center" @click="birthdayBtn">
  38. <text class="input-title">当前职位</text>
  39. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  40. placeholder="请选择您的当前职位" border placeholderClass='input-style' suffixIcon="arrow-right"
  41. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="from.birthday"></u--input>
  42. </view>
  43. <view class="body-input u-flex-col u-row-center" @click="birthdayBtn">
  44. <text class="input-title">期望职位</text>
  45. <u--input :disabled="true" disabledColor="#fff" customStyle="padding:0 !important" type="text"
  46. placeholder="请选择您的期望职位" border placeholderClass='input-style' suffixIcon="arrow-right"
  47. suffixIconStyle="font-size: 32rpx;font-weight: 400;color: #CACACA;" v-model="from.birthday"></u--input>
  48. </view>
  49. <view class="u-flex u-row-between" style="margin-top: 30rpx;">
  50. <view class="">
  51. 付费求职
  52. <image style="width: 32rpx;height: 32rpx;" src="/static/images/xiangguan.png" mode=""></image>
  53. </view>
  54. <u-switch v-model="value" @change="change"></u-switch>
  55. </view>
  56. <view class="button" @click="next">
  57. 保存
  58. </view>
  59. <u-datetime-picker ref="picker" title="求职时间" :minDate="minDate" @confirm="birthdayConfirm" :show="birthdayShow"
  60. mode="date" @cancel='birthdayShow = false'></u-datetime-picker>
  61. <u-picker ref="uPicker" keyName="name" title="期望城市" :defaultIndex="indexs" :show="cityShow" :columns="cityList"
  62. @confirm="cityconfirm" @cancel="cityShow = false" @change="changeHandler"></u-picker>
  63. </view>
  64. </template>
  65. <script setup>
  66. import {getAllArea } from "@/units/inquire.js"
  67. export default {
  68. data() {
  69. return {
  70. value: false,
  71. province: [], //省数据
  72. city: [], //市数据
  73. area: [], //区数据
  74. provinceid: "", //省数据
  75. cityid: "", //市数据
  76. areaid: "", //区数据
  77. indexs: [], //默认地区下标
  78. //选择器状态
  79. birthdayShow: false, //出生年月
  80. workShow: false, //工作时间
  81. cityShow: false, //户口所在地
  82. jobShow: false, //工作显示
  83. cityList: [], //数据地址
  84. cityids: [], //数据地址
  85. joblist: [],
  86. id:""
  87. }
  88. },
  89. onLoad(opsition){
  90. this.AllArea()
  91. this.id = opsition.id
  92. },
  93. methods: {
  94. change() {
  95. },
  96. //所有地区
  97. AllArea() {
  98. getAllArea().then((res) => {
  99. console.log(res);
  100. this.province = res.data.map(t => {
  101. return {
  102. name: t.name,
  103. id: t.id
  104. }
  105. })
  106. console.log("aaa", this.province);
  107. this.city = res.data.map(t => t.children.map(v => {
  108. return {
  109. name: v.name,
  110. id: v.id
  111. }
  112. }))
  113. this.area = res.data.map(t => t.children.map(v => v.children.map(i => {
  114. return {
  115. name: i.name,
  116. id: i.id
  117. }
  118. })))
  119. //默认显示数据
  120. // this.cityList = [
  121. // this.province.map(res => res.name),
  122. // this.city[0].map(res => res.name),
  123. // this.area[0][0].map(res => res.name)
  124. // ]
  125. let a = []
  126. let b = []
  127. let c = []
  128. this.province.map(res => {
  129. a.push({
  130. name: res.name,
  131. id: res.id,
  132. })
  133. })
  134. this.city[0].map(res => {
  135. b.push({
  136. name: res.name,
  137. id: res.id,
  138. })
  139. })
  140. this.area[0][0].map(res => {
  141. c.push({
  142. name: res.name,
  143. id: res.id,
  144. })
  145. })
  146. this.cityList = [a, b, c]
  147. // if (this.province && this.city && this.area) {
  148. // //省索引
  149. // let pIdx = this.province.findIndex(v => v.name == this.province);
  150. // //根据省索引设置默认市数据
  151. // this.columns[1] = this.city[pIdx].map(res => res.name)
  152. // //市索引
  153. // let cIdx = this.city[pIdx].findIndex(v => v.name == this.city);
  154. // //根据市索引设置默认区数据
  155. // this.columns[2] = this.area[pIdx][cIdx].map(res => res.name)
  156. // //区索引
  157. // let aIdx = this.area[pIdx][cIdx].findIndex(v => v.name == this.area);
  158. // this.indexs = [pIdx, cIdx, aIdx];
  159. // // console.log(pIdx, cIdx, aIdx);
  160. // console.log(this.indexs);
  161. // }
  162. // if (this.addressData.province && this.addressData.city && this.addressData.area) {
  163. // //省索引
  164. // let pIdx = this.province.findIndex(v => v.name == this.addressData.province);
  165. // //根据省索引设置默认市数据
  166. // this.columns[1] = this.city[pIdx].map(res => res.name)
  167. // //市索引
  168. // let cIdx = this.city[pIdx].findIndex(v => v.name == this.addressData.city);
  169. // //根据市索引设置默认区数据
  170. // this.columns[2] = this.area[pIdx][cIdx].map(res => res.name)
  171. // //区索引
  172. // let aIdx = this.area[pIdx][cIdx].findIndex(v => v.name == this.addressData.area);
  173. // this.indexs = [pIdx, cIdx, aIdx];
  174. // // console.log(pIdx, cIdx, aIdx);
  175. // console.log(this.indexs);
  176. // }
  177. })
  178. },
  179. changeHandler(e) {
  180. const {
  181. columnIndex, //当前改变值的列下标
  182. value,
  183. values, // values为当前变化列的数组内容
  184. indexs, //当前地区值下标
  185. picker = this.$refs.uPicker
  186. } = e
  187. //columnIndex代表第几列,意思是下标为0的列发生变化
  188. if (columnIndex === 0) {
  189. picker.setColumnValues(1, this.city[indexs[0]].map(v => {
  190. return {
  191. name: v.name,
  192. id: v.id
  193. }
  194. }))
  195. picker.setColumnValues(2, this.area[indexs[0]][0].map(v => {
  196. return {
  197. name: v.name,
  198. id: v.id
  199. }
  200. }))
  201. }
  202. if (columnIndex === 1) {
  203. picker.setColumnValues(2, this.area[indexs[0]][indexs[1]].map(v => {
  204. return {
  205. name: v.name,
  206. id: v.id
  207. }
  208. }))
  209. }
  210. },
  211. //点击显示时间选择器
  212. birthdayBtn() {
  213. this.birthdayShow = true
  214. //new Date(this.endDate).getTime()为你需要在选择器上显示的时间戳
  215. this.$refs.picker.innerValue = new Date(946656000000).getTime()
  216. },
  217. //出生日期选择器
  218. async birthdayConfirm(e) {
  219. const timeFormat = uni.$u.timeFormat;
  220. let timeValue = await timeFormat(e.value, 'yyyy-mm-dd');
  221. this.from.birthday = timeValue;
  222. this.birthdayShow = false
  223. },
  224. //户口地址
  225. cityconfirm(e) {
  226. let a = e.value[0].name + e.value[1].name + e.value[2].name
  227. let ids = String(e.value[0].id) + String(e.value[1].id) + String(e.value[2].id)
  228. this.from.domicile_city_id = e.value[1].id
  229. this.from.domicile_province_id = e.value[0].id
  230. // this.city1 = e.value.join("")
  231. this.city1 = a
  232. this.cityShow = false
  233. },
  234. }
  235. }
  236. </script>
  237. <style lang="scss">
  238. //个人信息
  239. .personal {
  240. width: 750rpx;
  241. background: #FFFFFF;
  242. border-radius: 28rpx 28rpx 0rpx 0rpx;
  243. margin-top: -40rpx;
  244. position: relative;
  245. z-index: 99;
  246. padding: 40rpx 32rpx 0;
  247. margin-bottom: 60rpx;
  248. box-sizing: border-box;
  249. .title {
  250. font-size: 48rpx;
  251. font-family: PingFangSC-Medium, PingFang SC;
  252. font-weight: 500;
  253. color: #222222;
  254. }
  255. .titleb {
  256. font-size: 26rpx;
  257. font-family: PingFangSC-Regular, PingFang SC;
  258. font-weight: 400;
  259. color: #777777;
  260. margin-top: 20rpx;
  261. }
  262. .body-input {
  263. height: 150rpx;
  264. border-bottom: 2rpx solid #F4F4F4;
  265. .input-title {
  266. font-size: 26rpx;
  267. font-family: PingFangSC-Regular, PingFang SC;
  268. font-weight: 400;
  269. color: #888888;
  270. margin-top: 30rpx;
  271. box-sizing: border-box;
  272. }
  273. .input-style {
  274. font-size: 32rpx;
  275. font-family: PingFangSC-Regular, PingFang SC;
  276. font-weight: 400;
  277. color: #CACACA;
  278. }
  279. }
  280. .button {
  281. width: 686rpx;
  282. height: 88rpx !important;
  283. background: #0C66C2;
  284. border-radius: 12rpx;
  285. font-size: 32rpx;
  286. font-family: PingFangSC-Medium, PingFang SC;
  287. font-weight: 500;
  288. color: #FFFFFF;
  289. line-height: 88rpx;
  290. margin: 54rpx 0 0rpx 0;
  291. display: flex;
  292. justify-content: center;
  293. }
  294. }
  295. </style>