作者:mobiledu2502904893 | 来源:互联网 | 2023-09-08 15:14
学习了vue.js一段时间,拿它来做2个小组件,练习一下。我这边是用webpack进行打包,也算熟悉一下它的运用。源码放在文末的github地址上。首先是index.html
学习了vue.js
一段时间,拿它来做2个小组件,练习一下。
我这边是用webpack
进行打包,也算熟悉一下它的运用。
源码放在文末的 github
地址上。
首先是index.html
我将 app
这个组件放在
内
通过webpack
打包后,入口的js文件是entry.js
,用来引入app.vue
组件
entry.js
let Vue = require('vue');
import App from './components/app';
let app_vue = new Vue({
el: '#main',
components: {
app: App
}
});
接下来看下这个app
组件
:comment-params="commentParams" :comment-is-sync="commentIsSync">
:page-params="pageParams" :page-is-sync="pageIsSync">
它有2个子组件,分别是comment.vue
和page.vue
,通过动态绑定数据,进行父子间组件通信,我是这样认为的,对于 当前在第几页
应当由 page.vue
传递给app.vue
,所以这里我们使用 双向绑定
,其余的如 params
, url
, isSync
,即向后台请求数据的东西以及是否同步或异步操作<当然,这里我还没有测试过后台数据,目前是直接js生成静态数据>。
接下来,看下comment.vue
评论组件
{{ totalCommentCount }} 条评论
{{ comment.name }}
{{ comment.context }}
这里的 getData.js
将在下面提到,是我们获取数据的位置。
loading
: 本意是在跳转页码加载评论时,对于当前评论加载0.5的透明度的遮罩,然后ajax通过它的回调函数来取消遮罩,现在这样就不能实现了,只能强行写下,然而是没有用的..
hasComment
: comment
组件第一次加载的时候,我们就去请求获得总共的数据长度,如果没有数据,则不显示comment
组件布局内容
·curPageIndex·: 通过父组件app
传递下来,使用的是props
这些数据,我们都设置一个默认值与类型比较好。
page.vue
主要是个对于 组件事件的运用,=最常见的click
事件,以及class
与style
的绑定,根据 curPageIndex
与this.pageIndex
来比较,判断是否拥有这个class
,通过computed
计算属性,来获得 页码数组 因为会根据当前页 有所变化,created
的时候 计算出总页码。
最后一个是 目前生成获取静态数据的js文件.
// let data = {
// avatar: '', 头像
// name: '', 用户名
// context: '', 评论内容
// }
let dataArr = [];
function randomStr (len) {
return Math.random().toString(36).substr(len);
}
function initData () {
for (var i = 0; i<45 ; ++i) {
let _avator = "./resources/" + i%7 + ".jpg";
let _name = randomStr(20);
let _cOntext= randomStr(2);
dataArr.push({
avatar: _avator,
name: _name,
context: _context
});
}
}
if (!dataArr.length) {
initData();
}
export function getCommentData (url = '', params = null, isSync = true, curPageIndex = 1, eachPageSize = 7) {
/* ajax */
let st = (curPageIndex - 1) * eachPageSize;
let end = st + eachPageSize;
return dataArr.slice(st, end);
}
export function getTotalCommentCount(url = '', params = null, isSync = true) {
/* ajax */
return dataArr.length;
}
export function getTotalPageCount(url = '', params = null, isSync = true, eachPageSize = 7) {
/* ajax */
return Math.floor((dataArr.length + eachPageSize -1 ) / eachPageSize);
}
就这样了吧。
github
地址