基于ColorUi-uniapp的⼀个列表实例1.页⾯样式
2.新建⼀个uniapp项⽬,导⼊ColorUi-nuiapp模板()
3.导⼊list组件()
4.列表页⾯代码
1<!--
2⽂件描述:绑定⽤户列表实例
3创建时间:2020/1/19 10:57
4创建⼈:Administrator
5-->
6<template>
7<view class="modelpage-list">
8<cu-custom bgColor="bg-gradual-blue" :isBack="true">
9<block slot="backText">返回</block>
10<block slot="content">{{pageTitle}}</block>
11</cu-custom>
12
13
14<uni-list class="listview" :enableBackToTop="true" :scroll-y="true" @scrolltolower="loadMore">
15<uni-refresh class="refresh" @refresh="onrefresh" @pullingdown="onpullingdown"
16 :display="refreshing ? 'show' : 'hide'">
17<div class="refresh-view">
18<image class="refresh-icon" :src="refreshIcon" :
19 :class="{'refresh-icon-active': refreshFlag}"></image>
20<uni-load-more v-if="refreshing" class="loading-icon" status="loading"
21 :contentText="loadingMoreText"></uni-load-more>
22<text class="loading-text">{{refreshText}}</text>
23</div>
24</uni-refresh>
25
26<uni-cell v-for="(item, index) in dataList" :key="item.id">
27<div class="userlist-item">
28<view class="cu-list menu-avatar comment solids-top">
29<view class="cu-item">
30<view class="cu-avatar round"
31 ></view> 32<view class="content">
33<view class="">
34<span class="text-xl text-bold">{{item.name}}</span>
35</view>
36<view class="cuIcon-phone text-content text-df margin-top-sm text-blue">
37 {{item.phonenumber}}
38</view>
39<view class="radius text-sm margin-top-sm">
40<view>{{plicitaddress}}</view>
41</view>
42<view class="margin-top-sm flex justify-between">
43<view class="cuIcon-time text-gray text-df"> {{ateDate}}</view>
44</view>
45</view>
46</view>
47</view>
48</div>
49</uni-cell>
50<uni-cell v-if="isLoading && !isFinished">
51<view class="loading-more">
52<text class="loading-more-text">{{loadingText}}</text>
53</view>
54</uni-cell>
55<uni-cell v-if="isFinished">
56<view class="loading-more">
57<text class="loading-more-text">已加载全部数据</text>
58</view>
59</uni-cell>
60</uni-list>
61
62<no-data class="no-data" v-if="isNoData" @retry="loadMore"></no-data>
63</view>
64</template>
65
66<script>
67// 这⾥可以导⼊其他⽂件(⽐如:组件,⼯具js,第三⽅插件js,json⽂件,图⽚⽂件等等)
68// 例如:import 《组件名称》 from '《组件路径》';
69// 例如:import uploadFile from '@/components/uploadFile/uploadFile'
70 import uniList from '@/components/uni-list.vue';
71 import uniCell from '@/components/uni-cell.vue';
72 import uniRefresh from '@/components/uni-refresh.vue';
73 import uniLoadMore from '@/components/uni-load-more.vue';
74 import noData from '@/components/nodata.nvue';
75
76 export default {
77 name: 'userlist',
78// import引⼊的组件需要注⼊到对象中才能使⽤
79 components: {
80 uniList,
81 uniCell,
82 uniRefresh,
83 uniLoadMore,
84 noData
85 },
86 data () {
87// 这⾥存放数据
88return {
89 requestParams: {
90 page: 1,
91 limit: 10
92 },
93 banner: {},
94 pageTitle: '绑定⽤户列表',
95 page: 1,
96
97 dataList: [],
98 navigateFlag: false,
99 pulling: false,
100 refreshing: false,
101 refreshFlag: false,
102 refreshText: "",
103 isLoading: false,
104 loadingText: '加载中...',
105 isFinished: false,
106 isNoData: false,
107 angle: 0,
108 loadingMoreText: {
109 contentdown: '',
110 contentrefresh: '',
111 contentnomore: ''
112 },
113 refreshIcon: " 114 };
115 },
116// 监听属性类似于data概念
117 computed: {},
118// ⽅法集合
119 methods: {
120 onLoad(event) {
121// ⽬前在某些平台参数会被主动 decode,暂时这样处理。
122try {
123this.banner = JSON.parse(decodeURIComponent(event.query));
124 } catch (error) {
125this.banner = JSON.parse(event.query);
126 }
127 console.log(this.banner)
128
129 uni.setNavigationBarTitle({
130 title: this.banner.name
131 });
132this.pageTitle = this.banner.name
133
135 },
136 loadMore() {
137this.loadingText = '加载中....'
139 },
140 onpullingdown(e) {
141 alert(2)
142if (freshing) {
143return;
144 }
145
146this.pulling = false;
147if (Math.abs(e.pullingDistance) > Math.abs(e.viewHeight)) {
150 } else {
153 }
154 },
155 getTypelist(refresh) {
156if (this.isLoading) return
157if (this.isFinished) return
158this.isLoading = true;
161 quest({
162 url: this.$Request,
163 data: questParams,
164 method: 'GET',
165 success: (result) => {
166 const data = result.data.list;
167
168 console.log(data)
169// this.isNoData = (data.length <= 0);
170// 查询出数据为空,显⽰加载完毕标识
171if (data.length === 0) {
172this.isLoading = false
173this.isFinished = true
174return
175 }
176this.isLoading = false;
177 const data_list = data.map((datalist) => {
178return {
179 id: datalist.id,
180 name: datalist.name,
181 addrid: datalist.addrid,
182 explicitaddress: plicitaddress,
183 phonenumber: datalist.phonenumber,
184 customsubtypename: datalist.customsubtypename,
185 createDate: ateDate
186 };
187 });
188
189if (refresh) {
190this.dataList = data_list;
192 } else {
193this.dataList = at(data_list);
195 }
196 },
197 fail: (err) => {
198 console.log(err);
199if (this.dataList.length == 0) {
200this.isNoData = true;
201 }
202 },
203 complete: (e) => {
204this.isLoading = false;
205if (refresh) {
209if (this.pullTimer) {
210 clearTimeout(this.pullTimer);
211 }
212this.pullTimer = setTimeout(() => {
213this.pulling = false;
214 }, 1000);
215 }
216 }
217 });
218 },
219 closeItem() {
220
221 },
222 goDetail(item) {
223 uni.navigateTo({
224 url: '/pages/index/detail?query=' + encodeURIComponent(JSON.stringify(item)) 225 });
226 },
227 onrefresh(e) {flutter uniapp 哪个好
229 },
230 refreshData() {
231if (this.isLoading) {
232return;
233 }
234this.pulling = true;
238 }
239 },
240// 监控data中的数据变化
241 watch: {},
242// ⽣命周期 - 创建完成(可以访问当前this实例)
243 created () {
244
245 },
246// ⽣命周期 - 挂载完成(可以访问DOM元素)
247 mounted () {
248
249 },
250 beforeCreate () {
251 }, // ⽣命周期 - 创建之前
252 beforeMount () {
253 }, // ⽣命周期 - 挂载之前
254 beforeUpdate () {
255 }, // ⽣命周期 - 更新之前
256 updated () {
257 }, // ⽣命周期 - 更新之后
258 beforeDestroy () {
259 }, // ⽣命周期 - 销毁之前
260 destroyed () {
261 }, // ⽣命周期 - 销毁完成
262 activated () {
263 } // 如果页⾯有keep-alive缓存功能,这个函数会触发
264 }
265</script>
266
267<style scoped lang="scss">
268 //@import url(); 引⼊公共css类
269
270</style>
View Code
5.页⾯css样式代码
// 列表页样式
.modelpage-list{
.listview {
position: absolute !important;
left: 0;
top: 50px;
right: 0;
bottom: 0;
/* #ifndef APP-NVUE */
display: flex;
flex-direction: column;
/* #endif */
/* #ifndef MP-ALIPAY */
flex-direction: column;
/* #endif */
}
.no-data {
flex: 1;
position: absolute;
left: 0;
top: 0;
right: 0;
bottom: 0;
z-index: 10;
}
.refresh {
justify-content: center;
}
.refresh-view {
/
* #ifndef APP-NVUE */
display: flex;
/* #endif */
width: 750 rpx;
height: 64px;
flex-direction: row;
flex-wrap: nowrap;
align-items: center;
justify-content: center;
}
.refresh-icon {
width: 32px;
height: 32px;
transition-duration: .5s;
transition-property: transform;
transform: rotate(0deg);
transform-origin: 15px 15px;
}
.refresh-icon-active {
transform: rotate(180deg);
}
.loading-icon {
width: 28px;
height: 28px;
margin-right: 5px;
color: gray;
}
.loading-text {
margin-left: 2px;
font-size: 16px;
color: #999999;
}
.loading-more {
align-items: center;
justify-content: center;
padding-top: 14px;
padding-bottom: 14px;
text-align: center;
}
.loading-more-text {
font-size: 28upx;
color: #999;
}
}
css样式
6.后台PHP请求数据代码
// 获取⼀个⽤户列表
case 'CESHI_getuserList':
$json_string = file_get_contents('E:\www\json\FeHelper-20200119143224.json');
$j= json_decode($json_string);
echo$json_string;
break;
PHP请求后台
7.数据结构
{
"list": [
{
"id": "1217823977957675010",
"name": "王XX",
"addrid": "370304XXX0000",
"explicitaddress": "博⼭⽯XXX",
"phonenumber": "1396XXXX646",
"customsubtypename": "居民普通户",
"createDate": "2020-01-16 23:00:37",
"deptId": "1067246875800000064"
},
{
"id": "1217823977957675010",
"name": "王XX",
"addrid": "370304XXX0000",
"explicitaddress": "博⼭⽯XXX",
"phonenumber": "1396XXXX646",
"customsubtypename": "居民普通户",
"createDate": "2020-01-16 23:00:37",
"deptId": "1067246875800000064"
},
{
"id": "1217823977957675010",
"name": "王XX",
"addrid": "370304XXX0000",
"explicitaddress": "博⼭⽯XXX",
"phonenumber": "1396XXXX646",
"customsubtypename": "居民普通户",
"createDate": "2020-01-16 23:00:37",
"deptId": "1067246875800000064"
}]
}
返回数据格式
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论