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>

效果图:

 

posted on 2020-04-26 16:37  JoeYoung  阅读(584)  评论(0编辑  收藏  举报