本文作者:程序员鱼皮
等了很久,终于收到落户批复啦!就差后面办一些手续。
落户批复
这篇文章首先分享一下自己作为一名本科生,通过攒积分成功落户上海的一些心得。然后手把手带大家使用 Vue
框架开发『 上海应届生落户积分计算器 』网站。
以前从没想过要留在上海,但后来在上海读书,待了一年后,有些习惯了,也逐渐开始爱上这座城市。
我是从大二开始确定落户目标的,一开始什么都不懂,也根本没想过要落户。虽然家长亲戚一直在我耳边叮嘱落户多么多么重要,但当时我的心态就是 “反正买不起房,落不落户不都一样?”
后来,自己上网查询了有关户口的信息,突然发现校园落户比社会落户要容易许多,现在清北复交等多所名校的学生甚至可以直接落户!
如果能在毕业时直接落户,将为以后省去不少的麻烦,即使买不起车房,但是先有一个户口总比没有好。
当时上海市落户积分 72 分才能达标,于是我就按照积分规则来简单计算了一下:
积分项 | 情况 | 得分 |
---|---|---|
最高学历 | 本科 | 21 |
毕业学校 | 第一类高校 | 15 |
最高学历毕业在沪 | 是 | 2 |
学习成绩 | 一级 | 8 |
外语水平 | 英语六级 | 8 |
计算机水平 | 计算机专业 | 7 |
用人单位分 | 满足条件 | 5 |
除了学历外,上述积分项我都拿到了最高分,但总计也只有 66 分,也就是说,如果没有任何竞赛、荣誉、专利等加分,距离落户还差整整 6 分!
怎么去凑这 6 分呢?在当时来看,我觉得参加竞赛是最好的选择,能抱一个大腿就更好啦!
于是,我的 “落户目标” 就简化为 “参加竞赛并拿奖”。首先仔细确认哪些竞赛奖项能为落户加分。
竞赛加分规则
其实对于计算机专业或者学习编程的同学来说,上面的很多比赛我们都可以参与,比如挑战杯、互联网+、数学建模等,会有一定的难度,所以最好趁早准备、报团取暖。
刚开始我试着自己组团参加了一些比赛,但结果都不是很理想, 后来有幸抱了其他学院的大腿,我们一起参与了挑战杯竞赛,并取得了上海市特等奖、全国二等奖的成绩,直接给落户加了十几分!
挑战杯现场
后来还拿了上海市优秀毕业生等其他荣誉,把竞赛奖项的加分直接拉满(15 分),最终以 81 分成功积分落户。
总结一下,给想落户的同学的建议是,尽早确认目标,先尽量保证基本分拿满,然后多去参加竞赛、争取一些荣誉称号,能力强的同学还可以试着申请一些发明专利。本科无法直接落户的同学也可以考虑读研,研究生阶段科研竞赛机会更多,落户也更容易。
为了帮助更多同学计算自己的落户积分,之前我也开发了一个单页面网站『 上海应届生落户积分计算器 』,就当一个练手项目了,下面一起来实践下吧!
做一个落户积分计算器非常简单,就是一个单页面网站的 Demo,使用 Vue
前端框架,除去输入文字的时间,只用 10 分钟就能完成开发和上线。
说是计算器,其实就是一个累加器,整个网站就是一个表单,用户可以根据自己的情况来选择对应选项,每个选项有不同的分数,在网站底部会实时显示当前的总分。
最终效果如下:
落户积分计算器
通过 Vue
的脚手架工具 Vue Cli
,输入一行命令,就可以轻松地搭建一个前端项目,还会自动安装依赖包:
vue create can-i-settle-shanghai
生成如下目录:
生成的项目文件
有了脚手架,真的轻松不少,不用再自己写项目的基础模板啦!
要做一个移动端网页,推荐引入一个精美的组件库,这里我推荐有赞的 Vant
,精致美观、文档成熟。
有赞 Vant 组件库
参照官方文档的 “快速上手” 部分,先在项目中引入 Vant
依赖:
npm i vant -S
然后直接全局引入,比较方便:
import Vue from 'vue';
import Vant from 'vant';
import 'vant/lib/index.css';
Vue.use(Vant);
之后就可以使用 Vant
的组件了,参照官方文档,选择组件后复制代码到页面文件即可:
使用组件
引入组件库后,就可以开发界面了。
开发界面就像拼图一样,将一个大的页面拆解为多个小的组件,然后自上而下堆积起来。
如下图,整个页面由 “标题”、“输入框”、“单选按钮组”、“底部展示按钮” 组成。
在 Vue
框架中,通常一个页面对应一个 .vue
文件。该文件分为三部分:内容、样式、行为,分别对应 HTML
、CSS
、JavaScript
代码。
一个标准的 .vue
文件如下:
<template>
... 写网页内容和结构
</template>
<script>
... 给页面添加交互行为
</script>
<style scoped>
... 写样式,美化网页
</style>
通常的开发流程是,先写内容,再去美化,最后再给网站添加交互行为。
编写内容比较简单,可以直接使用 Vant
的对应组件,比如 Radio 单选框
、Divider 分割线
、Field 输入框
。在文档中搜索,然后复制代码到项目页面文件中,部分代码如下:
<template>
<!-- 通过 style 属性控制单个标签样式 -->
<van-divider :style="{ color: '#1989fa', borderColor: '#1989fa'}">最高学历</van-divider>
<van-radio-group>
<van-radio name="27">博士27分</van-radio>
<van-radio name="24">硕士24分</van-radio>
<van-radio name="21">本科21分</van-radio>
</van-radio-group>
</template>
再编写一个按钮用于显示当前分数 total
,并且当 total
>= 72 时,改变按钮显示的颜色:
<van-button :type="total >= 72 ? 'primary' : 'info'">当前分数:{{total}}</van-button>
写完结构后,再然后美化一下样式,比如增加间距、调整字体等等,此处代码省略。
开发完网站的界面后,要增加交互行为,实现积分计算功能。每当用户点击选项或输入,都要触发一次计算,更新右下角的 “当前分数”。
可以定义一个 score
数组来记录得分,比如 “最高学历” 选项组的得分用 score[0]
来记录,“毕业学校” 选项组的得分用 score[1]
来记录。当然也可以用其他数据结构,如对象。
<script>
export default {
name: "Index",
// 在 data 中定义变量
data() {
return {
scores: [],
show: false,
};
}
}
</script>
用 v-model
指令绑定数组元素到选项组,同时要用 @change
指令给选项标签绑定一个点击事件,当用户点击界面选择时,改变当前 score
数组元素的值。每个选项有一个 name
属性,代表选中时的得分。
代码如下:
<template>
<van-radio-group v-model="scores[2]" @change="doChange">
<van-radio name="2">上海 2分</van-radio>
<van-radio name="0">非上海 0分</van-radio>
</van-radio-group>
</template>
比如我点击了 “上海 2分” 选项,scores[2]
的值就为 2。
那计算总分也就很简单了,只要将 score
数组元素累加求和,利用 Vue
的 computed
属性,可以轻松实现当 score
数组值变化时,自动更新总分 total
的值。
<script>
export default {
...
computed: {
// 定义 total 变量
total() {
let total = 0;
// 循环求和
for (const score of this.scores) {
if (score) {
total += parseInt(score);
}
}
return total;
}
}
}
</script>
计算功能就实现了!
本地开发完成后,怎么将网站发布,让所有人都能看到呢?
首先在项目目录下通过命令打包项目:
npm run build
会在生成 dist
目录,结构如下:
怎么发布网站到线上呢?先买台服务器?
大可不必,可以使用 Vercel
。
Vercel
是免费网站托管平台,可以帮我们轻松部署网站,并生成可访问的网址。先通过 npm
安装 Vercel
:
npm install -g vercel
安装完成后,进入 dist
目录,通过 vercel
命令发布网站:
cd public
vercel deploy --name can-i-settle-shanghai
发布成功,会得到一个网址,打开就能看到积分计算器网站啦!
就是这样,点击下方阅读原文可以查看项目的源代码。
其实很多问题都可以使用编程来解决,也希望大家在学编程的过程中,多多发挥自己的想象,并动手敲代码来实现创意,就能不断进步!
此心安处是吾乡,希望大家都能留在自己喜爱的城市,品味生活。