index.vue 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. <template>
  2. <div>
  3. <el-form class="select-list">
  4. <el-form-item label="驻场地点" class="select-item">
  5. <el-select v-model="city" placeholder="不限" @change="changeCity">
  6. <el-option label="全部" value=""></el-option>
  7. <el-option label="北京" value="1"></el-option>
  8. <el-option label="上海" value="2"></el-option>
  9. <el-option label="广州" value="3"></el-option>
  10. <el-option label="深圳" value="4"></el-option>
  11. <el-option label="成都" value="5"></el-option>
  12. <el-option label="杭州" value="6"></el-option>
  13. </el-select>
  14. </el-form-item>
  15. <el-form-item label="是否申请" class="select-item" v-if="Number(uid)>0">
  16. <el-select v-model="apply" placeholder="全部" @change="changeApply">
  17. <el-option label="是" value="1"></el-option>
  18. <el-option label="否" value="2"></el-option>
  19. </el-select>
  20. </el-form-item>
  21. </el-form>
  22. <div class="job-list">
  23. <template v-for="job in jobs">
  24. <div class="job-item" @click="jump(job.id)">
  25. <div class="job-header">
  26. <div class="title-wrapper">
  27. <div class="title">{{job.title}}</div>
  28. <div class="status-first">{{job.status_name}}</div>
  29. </div>
  30. <div class="price">¥ {{job.salary_from}}-{{job.salary_to}}</div>
  31. </div>
  32. <div class="job-content">
  33. <p><span>工作内容: </span><span class="description">{{job.job_description}}</span></p>
  34. <p><span>要求: </span>{{job.skills_name}}<span style="margin-left: 30px;">工作经验: </span>{{job.work_year}}年<span style="margin-left: 30px;">驻场地点: </span>{{job.city}}</p>
  35. </div>
  36. </div>
  37. </template>
  38. </div>
  39. <div class="pagination">
  40. <el-pagination background layout="prev, pager, next" :total="total" @current-change="changePage"/>
  41. </div>
  42. </div>
  43. </template>
  44. <script>
  45. import {Pagination} from "element-ui"
  46. export default {
  47. head() {
  48. return {
  49. title: '驻场工作招聘,2019年最新驻场工作招聘信息-程序员客栈',
  50. meta: [{
  51. 'name': 'keywords',
  52. 'content': '驻场招聘,驻场工作招聘,2019年最新驻场招聘信息'
  53. }, {
  54. 'name': 'description',
  55. 'content': '程序员客栈提供全国各地城市IT驻场工作最新招聘信息,核实企业资质,让有工作需求的程序员能得到一份满意的驻场工作;对程序员从业者能力进行严格把关,保障企业能在驻场招聘平台找到靠谱的程序员,确保项目正常进行。找工作、招聘合格的程序员,就上程序员客栈驻场招聘平台!'
  56. }]
  57. }
  58. },
  59. data() {
  60. return {
  61. city: '',
  62. apply: '',
  63. total: 0,
  64. jobs: [],
  65. page: 1,
  66. size: 10,
  67. uid: 0,
  68. }
  69. },
  70. mounted() {
  71. this.getData();
  72. },
  73. methods: {
  74. getData() {
  75. let formData = {page: this.page, size: this.size, city: this.city, has_apply: this.apply};
  76. this.$axios.$post('/api/present_job/index', formData).then(res => {
  77. this.jobs = res.data.jobs;
  78. this.total = Number(res.data.total);
  79. this.uid = Number(res.data.uid);
  80. })
  81. },
  82. changePage(page) {
  83. this.page = page;
  84. this.getData();
  85. },
  86. changeCity(city) {
  87. this.city = city;
  88. this.getData();
  89. },
  90. changeApply(apply) {
  91. console.log(apply);
  92. this.apply = apply;
  93. this.getData();
  94. },
  95. jump(id) {
  96. this.$router.push('/recruit/' + id);
  97. }
  98. }
  99. }
  100. </script>
  101. <style lang="scss" scope>
  102. .select-list {
  103. width: 100%;
  104. background-color: #ffffff;
  105. display: flex;
  106. align-items: center;
  107. }
  108. .select-item {
  109. margin: 25px;
  110. width: 300px;
  111. }
  112. .job-list {
  113. }
  114. .job-item {
  115. overflow: hidden;
  116. margin-top: 10px;
  117. width: 100%;
  118. height: 166px;
  119. background-color: #ffffff;
  120. cursor: pointer;
  121. }
  122. .job-header {
  123. margin-top: 33px;
  124. display: flex;
  125. align-items: center;
  126. }
  127. .title-wrapper {
  128. flex: 1;
  129. display: flex;
  130. align-items: center;
  131. }
  132. .title {
  133. margin-left: 20px;
  134. margin-right: 9px;
  135. font-weight: 500;
  136. font-size: 17px;
  137. color: #222222;
  138. }
  139. .status-first {
  140. padding: 3px 9px;
  141. border-radius: 1px;
  142. border: 1px solid #27BB6F;
  143. text-align: center;
  144. font-size: 11px;
  145. color: #27BB6F;
  146. }
  147. .status-second {
  148. padding: 3px 9px;
  149. border-radius: 1px;
  150. border: 1px solid #FF6600;
  151. text-align: center;
  152. font-size: 11px;
  153. color: #FF6600;
  154. }
  155. .status-third {
  156. padding: 3px 9px;
  157. border-radius: 1px;
  158. border: 1px solid #666666;
  159. text-align: center;
  160. font-size: 11px;
  161. color: #666666;
  162. }
  163. .price {
  164. margin-right: 20px;
  165. font-weight: 600;
  166. font-size: 16px;
  167. color: #FF331E;
  168. }
  169. .job-content {
  170. margin-top: 22px;
  171. margin-left: 20px;
  172. width: 620px;
  173. line-height: 27px;
  174. font-size: 13px;
  175. color: #333333;
  176. }
  177. .job-content span {
  178. font-weight: 500;
  179. }
  180. .pagination {
  181. overflow: hidden;
  182. margin-top: 10px;
  183. width: 100%;
  184. background-color: #ffffff;
  185. display: flex;
  186. justify-content: center;
  187. }
  188. .el-pagination {
  189. margin: 23px auto;
  190. }
  191. .description {
  192. padding-right: 10px;
  193. font-weight: normal !important;
  194. }
  195. </style>