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; 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>
效果图: