一、起步

1.引入reset.css解决手机之间不同分辨率的问题(reset.css为别人封装的css文件)

import './assets/styles/reset.css'

使用方式 1rem=50px

我们使用rem代替px

2.引入border.css解决手机边框1px的问题

import 'styles/border.css'

使用方式 class="top" //在添加上边框,同理 left、right、bottom

3.解决移动端点击事件存在300毫秒延迟问题

在项目目录运行cmd输入

npm install fastclick --save

在main.js中引入文件

import fastClick from 'fastclick'

实例化:fastClick.attach(document.body)

二、常用插件

1.stylus  简化css编写方式

安装:npm install stylus --save

再安装:npm install stylus-loader --save

使用方式:<style lang="stylus"></style>

2.axios   Ajax工具

安装: npm install axios --save

使用,法1:在需要使用的组件中<script>标签里引入

import axios from 'axios'

this.$axios()

使用,法2:

在main.js中引入
import axios from 'axios'

改为Vue的原型属性
Vue.prototype.$ajax=axios

直接调用this.$ajax()

例子:

this.$ajax.get('/api/index.json')
.then(function(res){
console.log(res)
})

3.vue-awesome-swiper 安装轮播插件(这里推荐使用2.6.7版)

安装:npm install vue-awesome-swiper@2.6.7 --save

使用方式:官方文档

4.better-scroll  滚动窗口插件

安装:npm install better-scroll --save

使用方式:

<div class="wrapper">
<ul class="content">
<li>...</li>
<li>...</li>
...
</ul>
<!-- 这里可以放一些其它的 DOM,但不会影响滚动 -->
</div> script中
import BScroll from 'better-scroll'
let wrapper = document.querySelector('.wrapper')//找到对应的标签
let scroll = new BScroll(wrapper)//实例化的第一个参数是一个原生的 DOM 对象 详情:官方文档 三、数据管理
Vuex 数据框架(进行数据传输)

/* 引入数据管理框架 */
import store from './store'

数据管理框架基础:

内容state(存公共数据)、actions、mutations(用于改变公用数据中的值)

如:

state: {
city: '成都'
},
actions: {
changeCity (ctx, city) {
// 调用mutations里对应的方法,city为所传值
ctx.commit('changeCity', city)
}
},
mutations: {
changeCity (state, city) {
state.city = city
}

注意:

1.采用dispatch调用index.js中actions对应的方法,city为所传的值
this.$store.dispatch('changeCity', city)

2.调用mutations里对应的方法,city为所传值
ctx.commit('changeCity', city)
改变值只能通过mutation方法区完成

3.调用公用数据方法

直接调用:this.$store.state.city

映射调用:

添加import { mapState } from 'vuex'
添加计算属性,将vuex里的city映射到计算属性的city中可直接调用this.city
computed: {
...mapState(['city'])
}

四、优化

 keep-alive标签

功能 标签内的内容会被放入内存中,只需渲染一次,不用每次访问都进行渲染
<keep-alive>
  <router-view/>
</keep-alive>
路由内的东西只需渲染一次,下次会直接从内存中调用数据
如果有每次进入都需要更新的数据可以使用生命钩子函数activated(){}
activated 在组件加载时调用
对应的 deactivated 在组件关闭时调用
前提需要使用 keep-alive
也可以这样写:
<keep-alive exclude="排除的组件名(不放入内存中,每次进入都会更新)">
内容。。。
</keep-alive>

五、开发环境的转发

编辑config里的index.js
找到proxyTable:{}
改写:
proxyTable: {
'/api':{
target: 'http://localhost:8080',
pathRewrite: {
'^/api': '/static/hithock'
}
}
}
//在开发环境访问时,将需要访问的api目录下的index.json改写为本地目录下static/hithock目录里
//前提需要用webpack

六、联机测试

1.要想服务可以通过ip地址访问需要改工程文件目录下的package.json中的 dev
添加 --host 0.0.0.0
变为:"dev": "webpack-dev-server --host 0.0.0.0 --inline --progress --config build/webpack.dev.conf.js"

七、项目打包

npm run build

打包出一个dist文件夹
将文件夹里的内容放到后端服务器上即可
当然,如果想改变文件的路径需要修改 config/index.js里面的打包内容如下:
assetsPublicPath: '/Travel', // 后端运行的目录
这里我们改为Travel目录

八、疑难问题

1.解决手机兼容性问题

npm install babel-polyfill --save //判断有无cs6新特性

2.使用better-scroll后click事件失效,解决方法

mounted(){
this.scroll=new Bscroll(this.$refs.wrapper, { mouseWheel: true, click: true, tap: true })
}
//better-scroll,默认它会阻止touch事件。所以在配置中需要加上click: true

OK!这就是我在项目中遇到的一些需要注意事项

最后:大家可以看一下我的成品。

易简图  ——一个专注于图片浏览资源器

欢迎骚扰!

vue项目常见需求(项目实战笔记)的更多相关文章

  1. vue实现音乐播放器实战笔记

    原文链接:https://blog.csdn.net/Forever201295/article/details/80266600 一.项目说明该播放器的是基于学习vue的实战练习,不用于其他途径.应 ...

  2. Spring Boot +Vue 项目实战笔记(二):前后端结合测试(登录页面开发)

    前言:关于开发环境 每位 Coder 都有自己偏好的开发工具,从大的方面划分主要有文本编辑器流和 IDE 流两种,我有一段时间也喜欢用编辑器(Sublime Text.Vim),但对我来说开发效率确实 ...

  3. mysql颠覆实战笔记(一)--设计一个项目需求,灌入一万数据先

    版权声明:笔记整理者亡命小卒热爱自由,崇尚分享.但是本笔记源自www.jtthink.com(程序员在囧途)沈逸老师的<web级mysql颠覆实战课程 >.如需转载请尊重老师劳动,保留沈逸 ...

  4. Unity3D项目实战笔记(10):Unity3D编译IPA的PostEvents–节约时间利器

    最近,SDK支付等接入差不多了,就从Unity3D生成IPA (企业版License), 然,需要手动执行的PostEvents竟然多大10项+, 这些我默默的承受了1周时间,每次约浪费20分钟-额外 ...

  5. Unity3D项目实战笔记(5):延时功能的几种实现

    我所做过的系统,分单机版系统(2005年).CS系统(2010年).实时系统(2015年),各个系统均有“延时”功能:定时调度的: 本博客说的是实时系统中的延时功能(基于Unity3D游戏引擎). 在 ...

  6. vue 饿了么项目笔记

    vue 饿了么项目 1.图标字体引用 链接 2.scss 二三倍图切换 1像素边框 链接 3.better-scroll 4.布局 商品主页面 <div id="app"&g ...

  7. Web项目开发介绍及实战项目介绍

    引言 本系列课程我们将学些Golang语言中的Web开发框架Iris的相关知识和用法.通过本系列视频课程,大家能够从零到一经历一个完整项目的开发,并在课程中了解实战项目开发的流程和项目设涉及的各个模块 ...

  8. Vue常用经典开源项目汇总参考-海量

    Vue常用经典开源项目汇总参考-海量 Vue是什么? Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的 渐进式框架.与其他重量级框架不同的是,Vue 采用自底向上增量开发的 ...

  9. 【前端】Vue.js经典开源项目汇总

    Vue.js经典开源项目汇总 原文链接:http://www.cnblogs.com/huyong/p/6517949.html Vue是什么? Vue.js(读音 /vjuː/, 类似于 view) ...

随机推荐

  1. C#中string类型是值类型还是引用类型?(转)

    出处:https://www.cnblogs.com/dxxzst/p/8488567.html .Net框架程序设计(修订版)中有这样一段描述:String类型直接继承自Object,这使得它成为一 ...

  2. Linux基础笔记

    基本命令: man man  查看手册 (1)pwd  显示路径 (2)cd  切换路径 (3)ls -a;-l;-h;-i;-d (隐藏的:长列表显示:human显示:索引号:只显示列表) (4)c ...

  3. warning: rpmts_HdrFromFdno: Header V4 DSA/SHA1 Signature, key ID 192a7d7d: NOKEY

    症状描述: 使用yum安装软件时报如下错误: warning: rpmts_HdrFromFdno: Header V4 DSA/SHA1 Signature, key ID 192a7d7d: NO ...

  4. Java获取文件后缀名

    int dot = filename.lastIndexOf('.'); if ((dot > -1) && (dot < (licenceImg.getOriginalF ...

  5. 解决Linux下IDEA无法使用ibus输入法的问题和tip乱码

    一:可以先按网上的配置/etc/profile里的输入法的一些参数,我是先配置了这些参数的,但是输入法还是没用,后来一直没管它了,今天用了一些方式可以了但不敢保证不需要先配置那些参数: 二:情况:开启 ...

  6. Redis源码笔记-初步

    目录 目录 1 1. 前言 2 2. 名词 2 3. dict.c 2 3.1. siphash算法 2 3.2. 核心函数 3 3.3. 核心宏 3 3.4. 核心结构体 3 3.4.1. dict ...

  7. Unicode和多字节的相互转换

    多字节转Unicode 四步: Step1 #include <iostream> #include "windows.h" using namespace std; ...

  8. 【1】jQuery异步(Ajax)操作之JSONP [转]

     前言: 说到AJAX就会不可避免的面临两个问题,第一个是AJAX以何种格式来交换数据?第二个是跨域的需求如何解决?这两个问题目前都有不同的解决方案,比如数据可以用自定义字符串或者用XML来描述,跨域 ...

  9. hibernate之三种时态之间的转换

    判断状态的标准 oid  和    session相关性 public class HibernateUtils { private static SessionFactory sessionFact ...

  10. Digital Roots—HDU1013 2016-05-06 10:25 85人阅读 评论(0) 收藏

    Digital Roots Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) To ...