Vue学习笔记(1).md

2017.4.11 - 4.13

前言:

上周大致浏览了Vue文档,简单使用了Vue.js文件尝试基本Vue特性。在这一周,学习Vue入门教程,完成了一个登录界面的Vue组件,并且通过与nodeJs的连接实现了登录验证。
在下一周中,学习Vue组件的套用,使用less完善css,使用Vuex管理项目状态。

笔记导航

  • Vue框架搭建
  • Vue前端组件搭建
  • Vue服务器端通信

项目要求

最新作业 具体要求

使用VUE实现求职系统,系统主要功能包括 注册,登录,职位查询,职位保存,求职跟踪,报表系统,具体要求如下:
新用户可以注册账号,注册需要通过email,系统将验证码发送到邮箱,用户需要填写验证码完成注册;
用户可以根据用户名和密码登录系统;
在职位查询中,用户可以根据公司名称,薪水,职位类型查询求职信息;
用户可以将查询中的某些记录加入到自己的关注信息;
用户可以将某些公司加入到求职跟踪,系统从招聘网站(比如智联招聘)抓取数据,并自动统计该公司每周的求职信息,发送给用户;
报表系统提供多种信息分析图表,比如各职位的数量饼状图,某职位的薪资变化图等等;
项目周期:3年级学生6周
知识要点:
1 . 掌握模板语法 v-html v-bind v-on v-show v-if v-for
2 . 理解vue-router路由模板以及路由事件的处理
3 . 掌握使用vue-resource访问网络服务
4 . 理解vuex状态管理模式
5 . 掌握使用webpack来模块化管理和打包

具体笔记

1. Vue项目的搭建

官方介绍文档
根据官方示例搭建环境,并且使用webpack依赖创建一个Vue项目

# 全局安装 vue-cli
$ npm install --global vue-cli
# 创建一个基于 webpack 模板的新项目
$ vue init webpack my-project
# 出现多行参数配置提示,一路回车就好
# 安装依赖,走你
$ cd my-project
$ npm install
# npm install因命令安装内容较多,需要时间比较久
$ npm run dev
# 执行run命令,即可运行程序自动打开浏览器并显示vue界面
# 此处使用的服务器端口号是8080,注意自己的电脑上是否有其他应用占用此端口,有则改之

项目创建完成之后,目录结构及其目录内文件功能说明如下图:

.
├── build/                      # webpack config files
│   └── ...
├── config/
│   ├── index.js                # main project config
│   └── ...
├── src/
│   ├── main.js                 # app entry file
│   ├── App.vue                 # main app component
│   ├── components/             # ui components
│   │   └── ...
│   └── assets/                 # module assets (processed by webpack)
│       └── ...
├── static/                     # pure static assets (directly copied)
├── test/
│   └── unit/                   # unit tests
│   │   ├── specs/              # test spec files
│   │   ├── index.js            # test build entry file
│   │   └── karma.conf.js       # test runner config file
│   └── e2e/                    # e2e tests
│   │   ├── specs/              # test spec files
│   │   ├── custom-assertions/  # custom assertions for e2e tests
│   │   ├── runner.js           # test runner script
│   │   └── nightwatch.conf.js  # test runner config file
├── .babelrc                    # babel config
├── .postcssrc.js               # postcss config
├── .eslintrc.js                # eslint config
├── .editorconfig               # editor config
├── index.html                  # index.html template
└── package.json                # build scripts and dependencies

./src/components/Hello.vue就是服务器启动后在浏览器中打开的vue组件,在编辑器中打开这个文件进行修改后保存,即可在浏览器中看到代码的同步更新。
如果出现语法错误或格式错误,浏览器也会直接提示error信息,十分简单粗暴便利。

2. Vue组件界面搭建

简明的入门视频教程Vue.js 2.0入门
Vue-resource 一个类似于ajax的工具
登录组件搭建:

<template>
    <div class="login">
        <form @submit.prevent='submit'>
            <label>username:&nbsp</label>
            <input type="text" v-model='user.username'>
            <br>
            <label>password:&nbsp</label>
            <input type="password" v-model='user.password'>
            <br>
            <input type="submit" value="submit">
        </form>
    </div>
</template>

<script>
export default {
  name: 'login',
  data () {
    return {
      user: {
        username: '',
        password: ''
      }
    }
  },
  methods: {
    submit: function () {
      // 向后台发送ajax请求
    }
  }
}
</script>

<style scoped>
.login {
  text-align: center;
}
</style>


3.后台处理登录请求

使用命令行创建express框架的新项目

express --view=hbs [project_name] 
npm install

实现Vue项目与node后台的连接
(跨域访问后台的教程)[http://www.imooc.com/article/8093]
关键在于设置访问来源地址

//在app.js中完成如下设置,即可实现两个端口进程之间的通信
app.all("*", function (req, res, next) {
  // 修改Access-Control-Allow-Origin的参数值,设成'*'会有收到不明攻击的危险,因此最好改成指定地址
  res.header('Access-Control-Allow-Origin', 'http://localhost:[node端口号]');
  res.header("Access-Control-Allow-Headers", "Content-Type,Content-Length, Authorization, Accept,X-Requested-With");
  res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
  if (req.method == 'OPTIONS') {
    res.send(200);
  } else {
    next();
  }
});

前端Vue界面

<template>
    <div class="login">
    // 此处触发submit函数,通过.prevent禁止页面的刷新跳转
        <form @submit.prevent='submit'>   
            <label>username:&nbsp</label>
            <input type="text" v-model='user.username'>
      <br>
            <label>password:&nbsp</label>
            <input type="password" v-model='user.password'>
            <br>
            <input type="submit" value="login">
      <p v-if='user.validated'>{{user.errmsg}}</p>
        </form>
    </div>
</template>

<script>
export default {
  name: 'login',
  data () {
    return {
      user: {
        username: '',
        password: '',
        validated: false,
        errmsg: ''
      }
    }
  },
  methods: {
    submit: function () {
      this.$http.post('http://localhost:8888/login', {
        username: this.user.username,
        password: this.user.password
      }).then(function (res) {
        // res即为服务器端发送过来的信息,通过res.body获取json数据
        console.log(res)
        this.user.errmsg = ''
        this.user.errmsg = res.body.errmsg
        this.user.validated = res.body.validated
        if (!res.body.validated) {
          alert('Welcome back, ' + this.user.username + ' !')
        }
      })
    }
  }
}
</script>

<style scoped>
.login {
  text-align: center;
}
</style>

后台服务器数据请求与处理

//app.js
var express = require('express');
var app = express();
var bodyParser = require('body-parser');
var morgan = require('morgan');

var MongoClient = require('mongodb').MongoClient;
var mongoUrl = 'mongodb://localhost:27017/zhaopin';
var _db;

app.use(morgan('dev'));
app.use(bodyParser.json());
app.use(express.static('dist'));


app.all("*", function (req, res, next) {
  res.header('Access-Control-Allow-Origin', 'http://localhost:8080');
  res.header("Access-Control-Allow-Headers", "Content-Type,Content-Length, Authorization, Accept,X-Requested-With");
  res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
  if (req.method == 'OPTIONS') {
    res.send(200);
  } else {
    next();
  }
});

// 连接mongodb数据库
MongoClient.connect(mongoUrl, function (err, db) {
  if(err) {
    console.error(err);
    return;
  }

  console.log('connected to mongo');
  _db = db;
  app.listen(8888, function () {
    console.log('server is running...');
  });
});

// ************ nodejs中的路由部分 ************
app.post('/login', function(req, res, next){
  var user  = req.body;
  console.log(user)
  var collection = _db.collection('user');
  if(!user.username || !user.password){
    res.send({validated: true, errmsg:"Please enter the entire info"});
    return;
  }
  collection.find({username: user.username}, function(err, ret){
    ret.toArray(function(err, doc){
      if (err) {
        console.log(err);
      }else if(doc.length == 1){
          if (doc[0].password == user.password) {
            res.send({validated: false, errmsg:''});
          } else {
            res.send({validated: true, errmsg:'Please enter the correct pwd...'})
            return;
          }
      }else{
        res.send({validated: true, errmsg: 'This account doesn\'t exist...'})
        return;
      }
    })
  })
})

app.post('/register', function(req, res, next){
  var user = req.body;
  var collection = _db.collection('user');
  if(!user.username || !user.password){
    res.send({validated: true, errmsg:"Please enter the entire info"});
    return;
  }
  collection.find({username: user.username}, function(err, ret){
    ret.toArray(function(err, doc){
      if (err) {
        console.log(err);
      }else if(doc.length == 1){
          res.send({validated: true, errmsg:"Sorry, this username has been registered!"});
          return;
      }else{
        collection.insert({username: user.username, password: user.password}, function(err, ret){
          if(err){
            console.error(err);
          }else {
            res.send({validated: false, errmsg: ''});
          }
        })
      }
    })
  });
})
// ************ nodejs中的路由部分 ************

完成效果图

用户注册界面
用户登录界面
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,271评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,725评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,252评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,634评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,549评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,985评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,471评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,128评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,257评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,233评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,235评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,940评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,528评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,623评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,858评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,245评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,790评论 2 339

推荐阅读更多精彩内容