You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
224 lines
4.8 KiB
224 lines
4.8 KiB
<template>
|
|
<view id="warp">
|
|
<view class="content">
|
|
<template v-if="speedList.length > 0">
|
|
<view
|
|
class="list_item"
|
|
v-for="(item,index) in speedList"
|
|
:key="index"
|
|
@tap="selectSpeedList(item)"
|
|
>
|
|
<view class="list_item_top">
|
|
<view class="list_item_lef">
|
|
<image src="/static/images/index/car_info_icon.png"></image> {{item.vehicleCode}} ({{item.vehiclePlate}})
|
|
</view>
|
|
<view class="list_item_right">
|
|
<image src="/static/images/common/speed.png"></image>
|
|
<text>{{item.speed}}km/h</text>
|
|
</view>
|
|
</view>
|
|
<view class="list_item_bot">
|
|
<view class="list_item_bot_bot">
|
|
<view class="list_item_bot_bot_left">报警时间:</view>
|
|
<view class="list_item_bot_bot_rig">{{item.gpsTime}}</view>
|
|
</view>
|
|
<view class="list_item_bot_bot">
|
|
<view class="list_item_bot_bot_left">报警位置:</view>
|
|
<view class="list_item_bot_bot_rig">{{item.address}}</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="bottomTitle" v-if="showNone">
|
|
<text>没有更多数据了 ~</text>
|
|
</view>
|
|
</template>
|
|
<template v-else>
|
|
<view class="blank">
|
|
<image src="/static/images/common/empty.png"></image>
|
|
<text>暂无记录</text>
|
|
</view>
|
|
</template>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
const {urlList,https} = require('@/static/api');
|
|
export default {
|
|
data() {
|
|
return {
|
|
speedList:[],
|
|
showNone:false,
|
|
isLoading:false, //是否在加载中
|
|
page:1,
|
|
pageSize:10,
|
|
};
|
|
},
|
|
onLoad() {
|
|
this.page = 1;
|
|
this.getSpeedList(1)
|
|
},
|
|
methods:{
|
|
selectSpeedList(item){
|
|
uni.navigateTo({
|
|
url: `/pages/warnItemInfo/warnItemInfo?data=${JSON.stringify(item)}`,
|
|
})
|
|
},
|
|
getSpeedList(page){
|
|
const _that = this;
|
|
https(urlList.getSpeedList+'/'+page+'/'+_that.pageSize,'GET','','加载中...').then(data => {
|
|
console.log('超速记录',data)
|
|
const list = data.data.list;
|
|
if(list.length !== 0){
|
|
if(page == 1){
|
|
_that.speedList = list;
|
|
}else{
|
|
_that.speedList = _that.speedList.concat(list);
|
|
}
|
|
}else{
|
|
if(_that.page > 1){
|
|
_that.page-=1;
|
|
}
|
|
_that.showNone = true;
|
|
}
|
|
_that.isLoading = false;
|
|
}).catch(err => {
|
|
uni.showToast({
|
|
title:err,
|
|
icon:'none',
|
|
duration:1500
|
|
})
|
|
_that.isLoading = false;
|
|
if(_that.page > 1){
|
|
_that.page-=1;
|
|
}
|
|
})
|
|
uni.stopPullDownRefresh();
|
|
},
|
|
},
|
|
onPullDownRefresh() {
|
|
this.page = 1;
|
|
this.getSpeedList(1);
|
|
},
|
|
onReachBottom() {
|
|
if(!this.isLoading){
|
|
this.isLoading = true;
|
|
this.page+=1;
|
|
this.getSpeedList(this.page);
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
page {
|
|
background-color: #F3F4F6;
|
|
}
|
|
</style>
|
|
<style lang="scss" scoped>
|
|
|
|
#warp{
|
|
width: 100%;
|
|
.content{
|
|
width: 100%;
|
|
display: flex;
|
|
flex-direction: column;
|
|
.list_item{
|
|
width: 100%;
|
|
height: 250rpx;
|
|
background-color: white;
|
|
margin-bottom: 20rpx;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
/* padding: 20rpx 0rpx; */
|
|
.list_item_top{
|
|
height: 80rpx;
|
|
width: 95%;
|
|
display: flex;
|
|
flex-direction: row;
|
|
align-items: center;
|
|
justify-content: space-between;
|
|
font-size: 14px;
|
|
}
|
|
.list_item_right{
|
|
display: flex;
|
|
flex-direction: row;
|
|
align-items: center;
|
|
color: #FF582D;
|
|
image{
|
|
width: 32rpx;
|
|
height: 32rpx;
|
|
margin-right: 6rpx;
|
|
}
|
|
}
|
|
.list_item_lef{
|
|
font-weight: bold;
|
|
color: #353535;
|
|
display: flex;
|
|
flex-direction: row;
|
|
align-items: baseline;
|
|
}
|
|
.list_item_lef image{
|
|
width: 35rpx;
|
|
height: 27rpx;
|
|
margin-right: 5px;
|
|
}
|
|
.list_item_bot{
|
|
width: 95%;
|
|
display: flex;
|
|
flex-direction: column;
|
|
border-top: 1rpx solid rgb(231, 230, 230);
|
|
font-size:14px;
|
|
.list_item_bot_bot{
|
|
display: flex;
|
|
flex-direction: row;
|
|
margin-top: 15rpx;
|
|
color: #363636;
|
|
}
|
|
.list_item_bot_bot_left{
|
|
width: 135rpx;
|
|
display: flex;
|
|
flex-wrap: nowrap;
|
|
}
|
|
.list_item_bot_bot_rig{
|
|
width: calc(100% - 175rpx);
|
|
text-overflow: -o-ellipsis-lastline;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
display: -webkit-box;
|
|
-webkit-line-clamp: 2;
|
|
line-clamp: 2;
|
|
-webkit-box-orient: vertical;
|
|
}
|
|
}
|
|
|
|
}
|
|
.bottomTitle{
|
|
width: 100%;
|
|
height: 100rpx;
|
|
color: #666666;
|
|
font-size: 24rpx;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
}
|
|
.blank{
|
|
width: 100%;
|
|
height: 100%;
|
|
font-size: 24rpx;
|
|
color: #999999FF;
|
|
margin-top: 30%;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
image{
|
|
width: 300rpx;
|
|
height: 240rpx;
|
|
margin-bottom: 40rpx;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|
|
|