vue-cli4初探、问题解决和心得
创建、调试、打包
vue create event-vue
npm run serve //这个好,官方推荐`vue serve`没用
npm run build
项目结构
- package.json 项目配置文件,含依赖配置,安装包的时候npm会自动去更新它
- app.vue 是顶级组件(可理解为首页)
- main.js 用来管理全局组件,我不喜欢用它
- vue.config.js 默认没有,但我创建了它,配置了全局变量,最终部署时需要它
- components 存在子组件,可被app引入
- assets 存放自己或手动下载的库/组件,可被引入
- public 存放完全静态的东西
添加组件
- 官方推荐用
vue add,实测很垃圾,用它装了axios根本不能用,是适配老的cli的。因此还是用npm install来安装包比较靠谱 - vant还是有点麻烦的,import要写两行以外,要使用van开头的标签, 还得在components里加代码,类似
Button,[Popup.name]:Popup,[Field.name]:Field,非常不优雅
自动刷新的问题
具体表现和简单:改有些代码时,页面不自动刷新。
解决方法就是能组件化就组件化。 因为在app.vue里改组件slot里的代码是可以自动刷新的。
自己导出模块
- 要使用第三方库的话, 可以
const axios=require('axios')也可以采用import的方式引入 - 导出用
module.exports或者export default方式 - 我自己的matchajs改造非常顺利
组合式API
一切都写在setup()内,最后return出来即可被template使用
如果provide出去,可被下级组件使用
需注意的是现在需视情况结合ref()和reactive()来定义data,否则return出去的东西若后面更改了,是不会响应式改变的
思路改变之后,再回到Option API的变成风格,会非常不适应(太不自由了)
reactive的机制导致踩坑
经测试, 发现let obj=reactive(new foo())这种方式来定义响应式对象的时候,如果foo实例化过程中含有异步回调, 那么回调时产生的数据改变, 不会触发响应式更新dom
原因非常简单, 因为响应式对象其实是一个Proxy对象。 仅当操作obj这个Proxy对象的时候才会触发响应式。 而foo实例化过程中的异步回调是对new foo()的结果进行改变, 并不符合触发条件。
vue-cli4初探、问题解决和心得的更多相关文章
- vue跨域问题解决(生产环境)
vue跨域问题解决(使用webpack打包的) 配置代理:(config下index.js文件) module.exports = { dev: { env: require('./dev.env') ...
- vue cli4.0 配置环境变量
温馨提示:本文只适用于vue-cli 3.0 及以上的版本哦~ ------------------正文开始------------------ 开发项目时,经常会需要在不同环境中切换.那么我们如何配 ...
- Vue CLI4.0版本正式发布了!一起来看看有哪些新的变化吧
Vue CLI4.0版本正式发布 这个主要的版本更新主要关注底层工具的必要版本更新.更好的默认设置和其他长期维护所需的微调. 我们希望为大多数用户提供平稳的迁移体验. Vue CLI v4提供了对Ni ...
- vue.js初探
前言 入手2016最火前端框架之一vue.js.大概从网上找了些资料看了下vue.js,从网上的资料来看只能惊叹其发展速度太快,让我意外的是其作者是华人的前提下作品这么受欢迎. 网上的博客和教程各种组 ...
- vue.js初探:计算属性和methods
在vue.js中,计算属性和methods方法的函数相同时,两者的最终执行结果都是相同的.然而不同的是,计算属性是基于它的依赖缓存.计算属性只有在它的相关依赖发生改变时才会重新取值.这就意味着只要 m ...
- vue学习初探
一.环境的搭建安装 VS Code vue开发环境的搭建 理解vue的脚手架 合适的cnpm版本
- 后端视角下的前端框架之Vue.js初探
背景 作为常年搞后端的自己来说,除了多年前学习的一点关于HTML的皮毛,对现在的前端技术栈可谓是一窍不通.但是因为最近在做的内部业务全链路监控系统,负责前端的同事做到一半去搞别的项目了,为了把项目落地 ...
- Vue SSR初探
因为之前用nuxt开发过应用程序,但是nuxt早就达到了开箱即用的目的,所以一直对vue ssr的具体实现存在好奇. 构建步骤 我们通过上图可以看到,vue ssr 也是离不开 webpack 的打包 ...
- vue 开发常见问题解决大全
vue添加favicon.ico,包含开发环境和生产环境显示. 1.把图标放在下项目的根目录.. 2.修改build文件夹下面的webpack.dev.conf.js(开发环境) 和webpack.p ...
- vue cli4.0 快速搭建项目详解
搭建项目之前,请确认好你自己已经安装过node, npm, vue cli.没安装的可以参考下面的链接安装. 如何安装node? 安装好node默认已经安装好npm了,所以不用单独安装了. 如何安装v ...
随机推荐
- Python矩阵作图库matplotlib的初级使用(2)
基础介绍 matplotlib图形对象层级结构: 图形对象(figure) → 子图对象(axes) → 坐标轴对象(axis) → 定位器对象-刻度线(locator)/格式化器对象-刻度线标签(f ...
- cookie报错 :服务器异常An invalid character [32] was present in the Cookie value
String KaptchaOwner= CommunityUtil.generateUUID(); Cookie cookie=new Cookie("kaptchaOwner" ...
- linux环境通过nginx转发allure报告
前言: 自动化测试生成的allure报告一般通过jenkins生成,生成后通过jenkins的view账号进行查看,但这样就必须登录jenkins才能看到,如何不通过登录jenkins从而看到al ...
- 前端面试-经典的Vue面试题
面试总结三大模块:Vue双向绑定及原理.生命周期.组件通信.Vue官方API 目录:1.Vue双向绑定及原理 1.1你对MVVM是怎么理解的? 1.2你对Vue响应式原理是怎么理解的?是否可以实现一个 ...
- gitea安装部署
安装gitea前需要先安装好git,具体参考https://www.cnblogs.com/magicMaQaQ/p/16062312.html 1.安装数据库,gitea支持多种数据库,这里选择my ...
- 性能再升级,XMeter Cloud 专业版正式上线
去年 8 月,EMQ 正式在全球市场推出了最简单.快速的 MQTT 负载和场景测试云服务--XMeter Cloud,用户无需部署即可进行 MQTT 测试,以更低的测试成本轻松打造具有竞争力的可靠物联 ...
- wpf 查找指定类型的子元素
public List<T> GetChildObjects<T>(DependencyObject obj, Type typename) where T : Framewo ...
- firewalld 防火墙centos7
在centos7中iptables已经废弃不用 firewalld命令: 查看所有规则 firewall-cmd --list-all 用命令行 来 允许40ip 访问本机 firewall-cmd ...
- Vue项目的打包方式(生成dist文件)
一.相关配置情况一(使用的工具是 vue-cil) 如果是用 vue-cli 创建的项目,则项目目录中没有 config 文件夹,所以我们需要自建一个配置文件:在根目录 src 下创建文件 vue.c ...
- 修改文件时mmap如何处理
拷贝二进制(elf)文件 在拷贝二进制文件的时候,如果文件是一个可执行文件,并且有一个进程在运行这个可执行文件,那么拷贝的时候会出现"文本忙"(ETXTBSY)的错误提示,并且拷贝 ...