data:image/s3,"s3://crabby-images/3b12e/3b12eee0fd35ca563a97dbf3699f131349f33ec0" alt=""
创建Server Folder. 然后分屏左边启动Client 右边进入Server
data:image/s3,"s3://crabby-images/32b63/32b63ae386f615bc4f8822db2876e6d80255dec0" alt=""
npm init -f 可以创建一个Package.json 在Server Folder里
install nodemon
data:image/s3,"s3://crabby-images/4a579/4a579b3905837f28b753ed3dc375744f0336027f" alt=""
往Script 里添加 start 和 lint. 这样npm run start/ npm run lint 就是启动这个
data:image/s3,"s3://crabby-images/2415d/2415d4ddd7fc142e648d55dd94e5d19a4cb5bc92" alt=""
在Server里src创建app.js
data:image/s3,"s3://crabby-images/13fda/13fda263c7fe8974ee9f33dacfe74f5a6aef22f8" alt=""
Npm install body-parser, express, cors, Morgan
data:image/s3,"s3://crabby-images/9424c/9424cfacc150766e31cb5762b6fe09ba3a44529a" alt=""
此时的Server/app.js 大概
data:image/s3,"s3://crabby-images/b1ab0/b1ab05008898c4c37ca0d67fe1810743a69cd274" alt=""
现在转入Vue.js 部分
创建一个Services Folder 创建api.js 和 authentication.js
data:image/s3,"s3://crabby-images/b7ecc/b7ecc1baf6de78a81d811cad373283bbb867d914" alt=""
data:image/s3,"s3://crabby-images/c57b0/c57b0d03c95b52623a462a0a71b252116ea9dd8b" alt=""
Router部分定义在index.js 这里我们设置一个route to register.
data:image/s3,"s3://crabby-images/b9a40/b9a401e48669b647cc155eaa8858bf2b522d595b" alt=""
在component Folder里 创建register component.
这里就是纯vue语法了, 比较重要的有v-model, which is a two direction bindings.
@click = "function name"
data:image/s3,"s3://crabby-images/3a054/3a054aa414a5856ec5cc023af536a96f6a16627c" alt=""
--------------------------------------------------------------
实现的几个牛逼功能:
1. 登录
data:image/s3,"s3://crabby-images/fbbd6/fbbd627fde2b6c847be12607c47670733553db10" alt=""
data:image/s3,"s3://crabby-images/e0f68/e0f68c52f56d853fc79a40ba479da7c4dc48b71b" alt=""
这里用到了一个two way bindings. 用户输入的value会进入component里的变量里,然后我们用this.email, this.password来登录
调用Store的方式 this.$store....
data:image/s3,"s3://crabby-images/6a886/6a88675015c7667285d16fdd733d0ae1ccad1e81" alt=""
这里最核心的就是调用AuthenticationService以及setToken,setUser 和router 切换。Login成功跳转到name位'songs'的component
data:image/s3,"s3://crabby-images/3cbfb/3cbfb918fb645816abfe50a7bd99d5dd8d03d8f9" alt=""
vuex 跟react-redux很像, 一个central store:
定义Store的property
state里面表示Store里存放的property
data:image/s3,"s3://crabby-images/8748c/8748c035e3ec77483a5d8368839b973edf711260" alt=""
在Server端:
先在Routes里定义:
data:image/s3,"s3://crabby-images/e3081/e30819a53a3cd51b84a923d0a6dd69798ab02a20" alt=""
定义AuthenticationController.js
我们可以从req.body里提取出用户传入的data。
data:image/s3,"s3://crabby-images/39ab2/39ab2ba7fcde39ab9ecccb2f32b37928f278aeab" alt=""
2. 搜索
data:image/s3,"s3://crabby-images/acdb5/acdb50922c0e253b147d103ef2075ea580d00f16" alt=""
使用lodash里的debounce方法,使搜索时候不会每个字都去搜索,而是等用户打完字几秒后开始。
***route.query 设置为this.search也就是用户输入的值。search也是two way binding
data:image/s3,"s3://crabby-images/fc43e/fc43ecf7a8f1d748095853c6ed25fd39054a6fc5" alt=""
3. Bookmarks
首先在model 里:
data:image/s3,"s3://crabby-images/33f2c/33f2c5721bb3be57e7dd20211c422ce6cb4d15c6" alt=""
在bookmarks Controller里, 这里userId是从req.user.id里取出来的原因是我们使用了middleware 往request里添加了一个新的field
req.user = USER
data:image/s3,"s3://crabby-images/3497c/3497c1d36bfd19cffa9a1d700dcb1832a91ca2d2" alt=""
在Policy Folder的IsAuthenticate.js里
data:image/s3,"s3://crabby-images/322ea/322ea6231eff4080eea164680f2a27af8d67cffa" alt=""
Client side:
Script里面的逻辑其实很简单,就是copy paste一个data-table和pagination.
data:image/s3,"s3://crabby-images/e1077/e107718efd991e1c70a4a7452096cb32b4869b43" alt=""
重点在于: page一呈现出来的时候立马使用mounted 然后取出bookmarks data。 然后data会被以Table的方式呈现。
data:image/s3,"s3://crabby-images/dcd0e/dcd0e9582aee9ebafe639cc9bf5c7321f5e9379f" alt=""
触发Favorite的问题
data:image/s3,"s3://crabby-images/90b07/90b076b39dabe08a64b36bb3fbbbef5750d82649" alt=""
data:image/s3,"s3://crabby-images/6932c/6932c6904f28e22a5732115b09796e7aa7596f55" alt=""
data:image/s3,"s3://crabby-images/76bd4/76bd4dae3c42f5c44594a506c728e36353ae7b74" alt=""
data:image/s3,"s3://crabby-images/4f713/4f713ac1c878051cadb844865c9f96b9d556ef69" alt=""
4. 历史记录
历史记录基本跟Bookmarks是一样的原理
data:image/s3,"s3://crabby-images/93441/93441baffc3df74b61a90bc45a893880f2e7c32e" alt=""
要注意的是,我们在详细浏览一个music的时候,要在mounted() 里post一个记录到SongHistoryService. 为什么只传入songId?因为 User info记录在persistent的cache里了?
data:image/s3,"s3://crabby-images/de3bc/de3bcabc113fb2620c504fd7462ffad81d39d9a9" alt=""
5. Youtube
vue-youtube-embe
其实很简单,只需要在数据库里存放Youtube链接的link就好了。
data:image/s3,"s3://crabby-images/9edde/9edde08dc07660f772842ac65a1a514ddbafba8b" alt=""
:video-id 那里放置 outer component传入的props: Youtube-id
data:image/s3,"s3://crabby-images/3a050/3a050f411eb23af914d3caedfe7429ce0d3ca5fc" alt=""
6. Passport Authenticate
data:image/s3,"s3://crabby-images/f7369/f73691d5dbeaaa6f04a368ea7e8dc5d006898a90" alt=""
Key is the token!!! 我们把这个token存放在store里。【突然意识到这样会不会影响到高并发?还是说因为VueJs是前端所以每个人的浏览器里有一个unique的Store?】
data:image/s3,"s3://crabby-images/b75ff/b75ff180da0ba167bb8a1e6b4dd62a983f900a33" alt=""
Model里的user.js
这个可以算做一个User Schema,专门用来造user。
data:image/s3,"s3://crabby-images/fb996/fb99623089056c2f9a4ada2a0a98ed0c59ef0366" alt=""
在AuthenticationController 里定义:
这里主要是给新建的user sign 一个token。
data:image/s3,"s3://crabby-images/5adce/5adced4ce1e294b30af125e3941e54a9b6413c6d" alt=""
看,这里的user可以调用comparePassword的方法。
data:image/s3,"s3://crabby-images/9a64c/9a64cb778701396d2c768c47b60921189aefa30b" alt=""
res.send(..) 是从server side send back to client side.
这里client side把response里的Token存入Store里。
data:image/s3,"s3://crabby-images/904f3/904f32ce4a41b35f86bc6fe5ab61b2ab61d90f9b" alt=""
data:image/s3,"s3://crabby-images/7dd05/7dd05149ce9d4cb24af6bf2b5a6e0eed07f8c3d9" alt=""
passport.js
JWT (JSON Web Token)
data:image/s3,"s3://crabby-images/94f2e/94f2ef23311d57ac3f77ee3d0d31da98201eac25" alt=""
划重点:
vuetify Icon
middleware injection
axios
export, require
data:image/s3,"s3://crabby-images/a0fe6/a0fe69cf1ea61e6ba3807e147e93b4763f582b46" alt=""
data:image/s3,"s3://crabby-images/f015b/f015be1b8b099ac9f8524ced43b662f83647be30" alt=""
Async await
Store
watch
Lodash
mounted
computed 我们需要知道他和Methods的区别。。。
效果其实差不多,但是主要是Performance原因
data:image/s3,"s3://crabby-images/6860f/6860f6cb3ceb4686345377766ade34f1613c21f0" alt=""
data:image/s3,"s3://crabby-images/eff19/eff19fa107a8bd0df35566c7567adb3d212683f7" alt=""
data:image/s3,"s3://crabby-images/889ce/889ce4b3c9928a8d91680ee31f303bb38d23e17f" alt=""
...mapState(){}
data:image/s3,"s3://crabby-images/788b8/788b82187cc1a340a3cde4c1b3873a490154aff2" alt=""
data:image/s3,"s3://crabby-images/dde61/dde618a214dc3fa16a2fa2ea848bad6033541fd1" alt=""
Methods需要被Explicitly 调用才可以,
比如
data:image/s3,"s3://crabby-images/be421/be42120cc1badd9721e0ba16f096a0e3e23240bb" alt=""
Computed会自动update DOM的值 whenever sth changed.
Example: https://codepen.io/Kradek/pen/gROQeB?editors=1010
data:image/s3,"s3://crabby-images/0fb7e/0fb7e362ec29444db493c30107a489132e356e02" alt=""
在Vue.js里import
位置是在vue file里的script区域:
import '../../../node_modules/vue-material-design-icons/styles.css'
SQL数据库NodeJs的创建:
网友评论