您的位置:首页 > 其它

软件工程实践2017 个人技术博客

2017-11-16 18:29 351 查看

目录

一、github项目管理

二、vue.js框架的搭建

三、通过axios调用api

四、javascript的Date对象

五、文件上传

六、javascript教程

一、github项目管理

参考资料:

廖雪峰的git教程

西瓜学长提供的github团队项目管理博客

其中主要碰到的问题是代码冲突,就是我在fetch upstream时,在同一个文件中,本地代码和远程代码不同,命令行给的提示信息是没办法智能合并,必须要手动merge。我在vscode里找到了合并代码的方法,可以手动选择使用传入的代码还是本地的代码。



二、vue.js框架的搭建

本次大作业,我们web前端选择的是vue.js框架。相比于我以往使用的Bootstrap框架来说,vue.js提供了一套更加完整的框架体系,能方便我们进行多人合作和前后端交互,它是一套构建用户界面的渐进式框架,便于与第三方库或既有项目整合,同时,当与单文件组件和Vue生态系统支持的库结合使用时,Vue也完全能够为复杂的单页应用程序提供驱动。同时,vue提供了一套我个人认为制作精美的组件,大家若使用此框架可尽情食用——>传送门

框架搭建参考资料:

vue安装教程

vue防坑指南

其中碰到一个模块的报错



我在防坑指南中找到了同样的情况


报错

Error: Cannot find module 'opn'

Error: Cannot find module 'webpack-dev-middleware'

Error: Cannot find module 'express'

Error: Cannot find module 'compression'

Error: Cannot find module 'sockjs'

Error: Cannot find module 'spdy'

Error: Cannot find module 'http-proxy-middleware'

Error: Cannot find module 'serve-index'

如果你用的是老版本的 vue-cli 还可能报其他错误,需要更新一下 vue-cli

npm update vue-cli

然后可以查看一下当前全局 vue-cli 的版本


更新完vue-cli的版本后,问题得到解决。

三、通过axios调用api

vue.js框架本身不提供支持外部api的工具,要通过使用Axios才能调用外部api,Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 vue.js 中。

从中提取了几点有用的功能来支持我的项目完成:

安装axios

执行get请求

错误处理

1、安装axios

$ npm install axios

2、执行get请求(post类似)

// 为给定 ID 的 user 创建请求
axios.get('/user?ID=12345')
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});

// 可选地,上面的请求可以这样做
axios.get('/user', {
params: {
ID: 12345
}
})
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});

3、错误处理

axios.get('/user/12345')
.catch(function (error) {
if (error.response) {
// 请求已发出,但服务器响应的状态码不在 2xx 范围内
console.log(error.response.data);
console.log(error.response.status);
console.log(error.response.headers);
} else {
// Something happened in setting up the request that triggered an Error
console.log('Error', error.message);
}
console.log(error.config);
});

四、javascript的Date对象

在发布作业的部分,我通过使用Iview的组件DatePicker来选择截止时间,其绑定的数据为js的Date对象格式,而api的参数要求如下



我一开始想直接通过Date.toString()来转成字符串再传给api,结果api返回值显示格式错误,一脸懵逼的我在控制台将Date对象转为字符串的结果输出,结果显示



本以为一个转字符串函数就能解决的问题,没想到还是要自己手动将Date格式化,于是我在网上找到教程

js日期格式化转换

同时结合Date的一些对象方法



最终完成了Date对象的格式转换,成功用api上传了发布作业的截止时间数据

(注:Date对象的月份,貌似比正常的少1,因此在处理的时候记得将Date对象中的月份+1)

五、文件上传

印象深刻的一个环节,花费了好多时间

上传文件代码1.0



使用iview组件库的Upload组件,结果控制台报错信息如下



之前碰到过类似的问题,知道应该是传参出错,由于使用的不是原生的form写法,不知道要怎么将参数cid和file一起加入(API的接口要求传参cid,file),就改成了原生form写法

上传文件代码2.0



这次的报错信息就更诡异了,如下



找资料发现,文件上传的格式跟普通表单上传不太一样,涉及到编码问题


定义和用法

enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码。

默认地,表单数据会编码为 "application/x-www-form-urlencoded"。就是说,在发送到服务器之前,所有字符都会进行编码(空格转换为 "+" 加号,特殊符号转换为 ASCII HEX 值)。


默认的enctype格式为application/x-www-form-urlencoded,要使用文件上传,必须将enctype改为multipart/form-data。于是我再次改变写法

上传文件代码3.0



这次总算获取到了正确的api返回值,截图留念。



收获:

1、框架提供的组件不熟,能用且用,不能用就用原生的

2、文件上传记得修改form的enctype属性

3、form中,action后的url中传参方式为get,若要用post,则要在Input中另写,并将form的method写为post

六、javascript教程

不要觉得这部分很多余!要用vue.js框架,javascript需要非常扎实的基本功!在整个前端开发的过程中,我大概重新查过了js的文档有35次左右,下面奉上js圣经。

参考资料:

MDS web docs

eloquentjavascript

看过了菜鸟教程、w3cschool等很多种教程,还是觉得mdn写得最全面,称之为圣经是一点都不为过,建议看英文版,中文的版本落后英文的好多。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: