Vue 简单实例 地址选配6 - 确认地址 - 地址列表渲染
1、在 pages 目录下,新建 Address.vue 文件,并引入头、尾和Modal组件:
<template><div>
<nav-header></nav-header>
<div class="nav-breadcrumb-wrap">
<div class="container">
<nav class="nav-breadcrumb">
<a href="/">首页</a>
<span>地址</span>
</nav>
</div>
</div>
<!-- 地址确认 -->
<div class="checkout-page">
<svg
style="position: absolute; width: 0; height: 0; overflow: hidden;"
version="1.1"
xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink"
>
<defs>
<symbol id="icon-add" viewBox="0 0 31 32">
<title>add</title>
<path
class="path1"
d="M30.745 15.152h-14.382v-14.596c0-0.308-0.243-0.557-0.543-0.557s-0.543 0.249-0.543 0.557v14.596h-14.665c-0.3 0-0.543 0.249-0.543 0.557s0.243 0.557 0.543 0.557h14.665v15.177c0 0.307 0.243 0.557 0.543 0.557s0.543-0.249 0.543-0.557v-15.177h14.382c0.3 0 0.543-0.249 0.543-0.557s-0.243-0.557-0.543-0.557z"
/>
</symbol>
<symbol id="icon-edit" viewBox="0 0 32 32">
<title>edit</title>
<path
class="path1"
d="M28.287 8.51l-4.805-4.806 0.831-0.831c0.472-0.472 1.086-0.777 1.564-0.777 0.248 0 0.452 0.082 0.622 0.253l3.143 3.144c0.539 0.54 0.133 1.529-0.524 2.186l-0.831 0.831zM26.805 9.992l-1.138 1.138-4.805-4.806 1.138-1.138 4.805 4.806zM24.186 12.612l-14.758 14.762-4.805-4.806 14.758-14.762 4.805 4.806zM7.379 28.288l-4.892 1.224 1.223-4.894 3.669 3.67zM31.123 4.011l-3.143-3.144c-0.567-0.567-1.294-0.867-2.103-0.867-1.036 0-2.174 0.52-3.045 1.391l-20.429 20.436c-0.135 0.134-0.23 0.302-0.276 0.487l-2.095 8.385c-0.089 0.355 0.017 0.736 0.276 0.995 0.198 0.198 0.461 0.307 0.741 0.307 0.085 0 0.171-0.010 0.254-0.031l8.381-2.096c0.185-0.047 0.354-0.142 0.487-0.276l20.43-20.436c1.409-1.41 2.042-3.632 0.524-5.15v0z"
/>
</symbol>
<symbol id="icon-del" viewBox="0 0 32 32">
<title>delete</title>
<path
class="path1"
d="M11.355 4.129v-2.065h9.29v2.065h-9.29zM6.194 29.935v-23.742h19.613v23.742h-19.613zM30.968 4.129h-8.258v-3.097c0-0.569-0.463-1.032-1.032-1.032h-11.355c-0.569 0-1.032 0.463-1.032 1.032v3.097h-8.258c-0.569 0-1.032 0.463-1.032 1.032s0.463 1.032 1.032 1.032h3.097v24.774c0 0.569 0.463 1.032 1.032 1.032h21.677c0.569 0 1.032-0.463 1.032-1.032v-24.774h3.097c0.569 0 1.032-0.463 1.032-1.032s-0.463-1.032-1.032-1.032v0z"
/>
<path
class="path2"
d="M10.323 9.806c-0.569 0-1.032 0.463-1.032 1.032v14.452c0 0.569 0.463 1.032 1.032 1.032s1.032-0.463 1.032-1.032v-14.452c0-0.569-0.463-1.032-1.032-1.032z"
/>
<path
class="path3"
d="M16 9.806c-0.569 0-1.032 0.463-1.032 1.032v14.452c0 0.569 0.463 1.032 1.032 1.032s1.032-0.463 1.032-1.032v-14.452c0-0.569-0.463-1.032-1.032-1.032z"
/>
<path
class="path4"
d="M21.677 9.806c-0.569 0-1.032 0.463-1.032 1.032v14.452c0 0.569 0.463 1.032 1.032 1.032s1.032-0.463 1.032-1.032v-14.452c0-0.569-0.463-1.032-1.032-1.032z"
/>
</symbol>
</defs>
</svg>
<div class="container">
<div class="checkout-addr">
<div class="page-title-normal">
<h2 class="page-title-h2">
<span>结算</span>
</h2>
</div>
<!-- process step -->
<div class="check-step">
<ul>
<li class="cur">确认地址</li>
<li>查看订单</li>
<li>支付</li>
<li>订单 确认</li>
</ul>
</div>
<!-- address list -->
<div class="page-title-normal checkout-title">
<h2>
<span>配送地址</span>
</h2>
</div>
<div class="addr-list-wrap">
<div class="addr-list">
<ul>
<li class="check">
<dl>
<dt>河畔一角</dt>
<dd class="address">北京市昌平区</dd>
<dd class="tel">17600000000</dd>
</dl>
<div class="addr-opration addr-del">
<!-- 删除地址 -->
<a href="javascript:;" class="addr-del-btn">
<svg class="icon icon-del">
<use xlink:href="#icon-del" />
</svg>
</a>
</div>
<div class="addr-opration addr-set-default">
<a href="javascript:;" class="addr-set-default-btn">
<i>设为默认</i>
</a>
</div>
<div class="addr-opration addr-default">默认地址</div>
</li>
<li class="addr-new">
<div class="add-new-inner">
<i class="icon-add">
<svg class="icon icon-add">
<use xlink:href="#icon-add" />
</svg>
</i>
<p>添加地址</p>
</div>
</li>
</ul>
</div>
<div class="shipping-addr-more">
<a class="addr-more-btn up-down-btn open" href="javascript:;">
查看更多
<i class="i-up-down">
<i class="i-up-down-l"></i>
<i class="i-up-down-r"></i>
</i>
</a>
</div>
</div>
<!-- shipping method-->
<div class="page-title-normal checkout-title">
<h2>
<span>配送方式</span>
</h2>
</div>
<div class="shipping-method-wrap">
<div class="shipping-method">
<ul>
<li class="check">
<div class="name">标准配送</div>
<div class="price">免费配送</div>
<div class="shipping-tips">
<p>一旦发货,订单应在1-7个工作日内到达目的地</p>
</div>
</li>
</ul>
</div>
</div>
<div class="next-btn-wrap">
<a class="btn btn--m btn--red" href="#">下一步</a>
</div>
</div>
</div>
</div>
<modal></modal>
<navFooter></navFooter>
</div>
</template>
<script>
import navHeader from '../components/Header'
import navFooter from '../components/Footer'
import Modal from '../components/Modal'
export default {
name: 'Address',
components: {
navHeader,
navFooter,
Modal
}
}
</script>
效果图:
2、发起网络请求,循环地址列表:
<li class="check" v-for="item in addrList" :key="item.addressId"><dl>
<dt>{{ item.userName }}</dt>
<dd class="address">{{ item.streetName }}</dd>
<dd class="tel">{{ item.tel }}</dd>
</dl>
<div class="addr-opration addr-del">
<!-- 删除地址 -->
<a href="javascript:;" class="addr-del-btn">
<svg class="icon icon-del">
<use xlink:href="#icon-del" />
</svg>
</a>
</div>
<div class="addr-opration addr-set-default">
<a href="javascript:;" class="addr-set-default-btn">
<i>设为默认</i>
</a>
</div>
<div class="addr-opration addr-default">默认地址</div>
</li>
<script>
export default {
data() {
return {
addrList: []
}
},
methods: {
getAddress() {
this.axios.get('/mock/address.json').then(res => {
console.log(res)
this.addrList = res.data.data
})
}
}
}
</script>
此时效果图:
可以看到默认地址和设为默认是重叠的,这时要根据每一条数据的 isDefault 字段来判断是否是默认地址。
3、是否为默认地址
<div v-if="!item.isDefault" class="addr-opration addr-set-default"><a href="javascript:;" class="addr-set-default-btn">
<i>设为默认</i>
</a>
</div>
<div v-if="item.isDefault" class="addr-opration addr-default">默认地址</div>
效果图:
以上是 Vue 简单实例 地址选配6 - 确认地址 - 地址列表渲染 的全部内容, 来源链接: utcz.com/z/375611.html