vue 开发采坑实记

一、安装并使用iview全局样式
①安装

$ npm install view-design --save

②在main.js中全局引入

# main.js
import ViewUI from 'view-design';
import 'view-design/dist/styles/iview.css';

...

Vue.use(ViewUI);

③使用iview的 List

    <List>
      <ListItem v-for="(item, index) in bookList">
        <ListItemMeta :avatar="item.cover" :title="item.bookName"  />
      </ListItem>
    </List>

④修改iview的样式参数

<style scoped>

>>>.ivu-avatar {
  border-radius: 0% !important;
}

</style>

⑤使用分页Page时,如果监测不到当前页码数时要考虑.sync修饰符

      <Page :current.sync="currentPage" :total="total" :page-size="8" />

⑥遇到click事件无响应,加上native修饰符

        <ListItemMeta :avatar="item.cover" :title="item.bookName" @click.native="currentBookId(item.uniqueId)" />

⑦遇到全局提示Message的error方法无法使用的情况
将ViewUI引入使用

import ViewUI from 'view-design';
·...
      // this.$Message.error(err.response.data.msg)  这样会报错,但是this.$Message.success()方法不会报错
      ViewUI.Message.error(err.response.data.msg)

二、在vue项目中打开外部完整链接(如打开‘www.baidu.com’)

        window.location.href = res.url

三、数据保存到vuex中,但是一刷新页面,或者有页面跳转情况,vuex中保存的数据会丢失。此时可以考虑将数据保存到本地session storage中。
即“vuex的store中的数据有一个特性,那就是在页面刷新时,页面会重新加载vue实例,store里面的数据就会被重新赋值,这样就会出现页面刷新vuex中的数据丢失的问题。”
解决方案之一如下:
安装插件:

npm install vuex-persistedstate  --save

然后配置store中的index.js文件

import Vue from 'vue'
import Vuex from 'vuex'

import createPersistedState from "vuex-persistedstate"

Vue.use(Vuex)

export default new Vuex.Store({
  // 安装插件,将vuex中的数据保存到本地session storage中,避免刷新一下vuex中的数据就丢失
  plugins: [createPersistedState({
    storage: window.sessionStorage
  })],
  state: {
    bookInfo: null
  },
  mutations: {
    setBookInfo(state, book) {
      state.bookInfo = book
    }
  },
  actions: {

  },
  modules: {
  }
})

四、vue跨域问题(绕不过去,还是写一下吧)
本人用的cli4,遇到了跨域问题,按照面向百度编程的思维方式,试了多种方式,其中可能性最高的一种,同时也是在github上找的,在项目根目录创建vue.config.js文件,进行如下配置:

# vue.config.js
module.exports = {
  devServer: {
    port: 8081, // 端口号
    https: false, // https:{type:Boolean}
    open: true, // 配置自动启动浏览器
    hotOnly: true, // 热更新
    proxy: {
      // 配置跨域
      '/api': {
        target: 'https://xxxxxx.com',//跨域接口的地址(真实api地址)
        changeOrigin: true, // 允许跨域
        pathRewrite: {
         '^/api': '/'
         }
      }
    },
    headers: {
      'Access-Control-Allow-Origin': '*',
    }
  }
};

可参考github地址:“https://github.com/staven630/vue-cli4-config/blob/master/vue.config.js
本以为会万事大吉,却发现行不通,之后又搞了半天,无果,想着要后端处理一下,然后资讯同事使用如下配置,解决了问题(本彩笔很后悔没早问同事,浪费时间了)

#vue.config.js
module.exports = {
  configureWebpack: {
    resolve: {
      alias: {
        'assets': '@/assets',
        'common': '@/common',
        'components': '@/components',
        'network': '@/network',
        'views': '@/views',
        'store': '@/store',
      }
    }
  },
  devServer: {
    port: 8081, // 端口号
    https: false, // https:{type:Boolean}
    open: true, // 配置自动启动浏览器
    hotOnly: true, // 热更新
    proxy: {
      // 配置跨域
      '/api': {
        target: 'https://xxxx',//跨域接口的地址
        changeOrigin: true, // 跨域
        source: false  // 主要问题(重点),
      }
    },
    headers: {
      'Access-Control-Allow-Origin': '*',
    }
  }
};

请求配置如下:

# axios or request.js
import Vue from 'vue';
import axios from 'axios';
import Token from "../common/token";
import Device from "../common/device";


const Axios = axios.create({
  baseURL: '/api',
  timeout: 5000,
});

Vue.config.productionTip = false

// 添加请求拦截器
Axios.interceptors.request.use((config) => {
  config.headers['Content-Type'] = 'application/x-www-form-urlencoded'
  // headers中增加设备唯一码
  const device_uuid = Device.get() || ''
  // console.log(device_uuid)
  if (device_uuid) config.headers['Device-UUID'] = device_uuid;

  // 携带cookie
  const token = Token.get() || ''
  // 后台token验证
  if (token) config.headers.Authorization = 'Bearer ' + token;
  console.log(config)
  return config;
}, (err) => {
  // 对请求错误做些什么
  return Promise.reject(err);
});

// 添加响应拦截器
Axios.interceptors.response.use(res => {
  // 对响应数据做点什么
  return res.data;
}, err => {
  // 对响应错误做点什么
  // console.log(err)
  return Promise.reject(err);
});

export default Axios;

五、post请求(用户登录)时数据一直请求不成功(囧),后端只返回状态码400,有效信息太少,后来发现请求时的参数data被转换成了字符串(啊啊啊啊啊啊啊,md)


image.png

解决方法:
使用qs插件···先安装

npm install qs

配置:main.js中全局引入

import  qs from 'qs'
....
// qs
Vue.prototype.$qs = qs

使用

# user.js
import qs from 'qs'

const params = qs.stringify({
    username,
    password
  })

此时的data变成这样:


image.png

注:
qs.stringify()是将对象 序列化成URL的形式,以&进行拼接。
qs.parse()是将URL解析成对象的形式。

附上一些基础知识:

1、事件总线$bus,可用于兄弟组件传值
用法:
main.js声明

# main.js

Vue.prototype.$bus = new Vue()

使用
兄弟发送事件+数据

      this.$bus.$emit("event", column_id);

接收:

  mounted() {
    // 接收兄弟传来的事件总线
    this.$bus.$on("event", (res) => {
      console.log(res);
    });
  },

2、获取左滚动距离单位
页面

<div class="column" ref="second">
</div>

获取

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

推荐阅读更多精彩内容