vue 2.6.0 新增了 Vue.observable api,但最近才去尝试使用它。
这东西说新也不新,因为他就是 vue 本身的功能,只是暴露出来,成为新 api 了。
在老版本中,直接用 new Vue({ data: {} }) 也一样。
官方文档原文描述是: 让一个对象可响应。Vue 内部会用它来处理 data 函数返回的对象。
然后百度一下这个,几乎全是 使用Vue.observable()进行状态管理 这种文章。
谷歌一下也一样,然后你会发现,国内的文章都是翻译过来的。
所以我想试试能不能做点其他东西。
我创建了一个可响应对象, const state = Vue.observable({ count: 1 }); ,然后尝试挂载到 data 和 computed 下,发现都可以用,然后我在 state 上加了个方法。
const state = Vue.observable({ count: 1 });
state.add = () => state.count++;
const app = new Vue({
data: {
state,
},
});
当挂载到 data 下,我发现 add 没被代理,所以推测 vue 直接挂载 Vue.observable 创建的对象。
我之前做分页,都需要 data 下挂个对象,然后需要计算属性计算当前显示列表。
现在我们可以尝试使用 Vue.observable 封装一个分页方法。
/**
* 生成分页
* @param {any[]} list 数据列表
* @param {number} size 每页条数
*/
const pagination = (list, size = 10) => {
const res = Vue.observable({
/** 当前页码 */
page: 1,
/** 每页条数 */
size,
/** 总页数 */
total: Math.ceil(list.length / size),
/** 当前页显示数据 */
list: [],
});
/** 原数组 */
res.orgList = list;
/** 分页方法 */
res.setPage = (num) => {
res.page += num
const { page, size } = res;
const pos = (page - 1) * size;
res.list = res.orgList.slice(pos, pos + size);
}
// 初始化
res.setPage(0);
return res;
};
代码比较简化,没写 ajax 分页支持,就用最简单的例子来演示,以便于理解。
这个例子中 Vue.observable 将分页功能封装到一个函数中确实简化了不少。
也许还有更多场景可以使用它来优化,那就等待大家去挖掘吧,别再一味翻译国外的文章。
VueJS 实际开发中会遇到的问题,主要写一些 官方手册 上没有写,但是实际开发中会遇到的问题,需要一定知识基础。
Vue.js是一套构建用户界面的渐进式的前端框架。 vueJS与后台交互数据的方法我所了解的有以下几种
Vue是一套构建用户界面的JS渐进式框架。 Vue 只关注视图层, 采用自底向上增量开发的设计。讲解js高级之响应式、过渡效果、过渡状态。
深入理解Vue.js响应式原理。Vue教程有关的视频都讲到,我习惯响应式开发,在更早的Angular1时代,我们叫它:数据绑定(Data Binding)。你只需要在Vue实例的 data() 块中定义一些数据,并绑定到HTML
在vue组件中,为了使样式私有化(模块化),不对全局造成污染,可以在style标签上添加scoped属性以表示它的只属于当下的模块,这是一个非常好的举措,但是为什么要慎用呢?因为scoped往往会造成我们在修改公共组件(三方库或者项目定制的组件)的样式困难,需要增加额外的工作量
vue现在使用的人越来越多了,这篇文章主要整理一些比较优秀的移动端ui框架,推荐给大家,例如:mint UI、vux、vonic、vant、cube-ui、Muse-ui、Vue-Carbon、YDUI等
webpack是开发Vue单页应用必不可少的工具,它能管理复杂的构建步骤,并且优化你的应用大小和性能, 使你的开发工作流更加简单。在这篇文章中,我将解释使用webpack提升你的Vue应用的4种方式,包括:单文件组件、优化Vue构建过程、浏览器缓存管理、代码分离
Vue-Access-Control是一套基于Vue/Vue-Router/axios 实现的前端用户权限控制解决方案,通过对路由、视图、请求三个层面的控制,使开发者可以实现任意颗粒度的用户权限控制。
Web 中的组件其实就是页面组成的一部分,具有高内聚性,低耦合度,互冲突等特点,有利于提高开发效率,方便重复使用,简化调试步骤等。vue 中的组件是一个自定义标签形式,扩展原生的html元素,封装可重用的代码。
Vue的实例是Vue框架的入口,其实也就是前端的ViewModel,它包含了页面中的业务逻辑处理、数据模型等,当然它也有自己的一系列的生命周期的事件钩子,辅助我们进行对整个Vue实例生成、编译、挂着、销毁等过程进行js控制。
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!