Home  >  Article  >  Web Front-end  >  UniApp Design and Development Guide for Implementing List Pages and Details Pages

UniApp Design and Development Guide for Implementing List Pages and Details Pages

王林
王林Original
2023-07-05 09:21:062964browse

UniApp is a cross-platform development framework based on Vue.js, which can quickly build mobile applications, small programs and H5 pages. In UniApp, it is a very common requirement to implement the design and development of list pages and detail pages. This article will introduce you to how to design and develop list pages and details pages in UniApp, and explain it through code examples.

1. Design the list page
When designing the list page, we first need to determine the data displayed in the list and the display method. The following is a simple example showing a product list:

<template>
  <view>
    <navigator v-for="product in productList" :url="'/pages/detail?id=' + product.id">
      <image :src="product.imgUrl" class="product-img" mode="aspectFit"></image>
      <text>{{ product.name }}</text>
      <view class="product-info">
        <text>价格:{{ product.price }}</text>
        <text>库存:{{ product.stock }}</text>
      </view>
    </navigator>
  </view>
</template>

<script>
  export default {
    data() {
      return {
        productList: [
          {
            id: 1,
            imgUrl: 'http://example.com/product1.jpg',
            name: '商品1',
            price: 100,
            stock: 10
          },
          {
            id: 2,
            imgUrl: 'http://example.com/product2.jpg',
            name: '商品2',
            price: 200,
            stock: 20
          }
        ]
      }
    }
  }
</script>

<style scoped>
  .product-img {
    width: 200rpx;
    height: 200rpx;
  }

  .product-info {
    display: flex;
    justify-content: space-between;
  }
</style>

In the above code, we use the 90553a25cfb9c2089e9e88a5e7e05f40 component to realize that clicking on each product jumps to the details page ; Use dc0870658837139040642baa5555a380 and 28f128881ce1cdc57a572953e91f7d0f components to display product pictures, names, prices, inventory and other information. Use the v-for instruction to traverse the productList array to display multiple products.

2. Design the details page
The details page generally displays the detailed information of a single product. When designing the details page, we can display more product information based on actual needs, such as product descriptions, specifications, reviews, etc. The following is a simple example showing product details:

<template>
  <view>
    <image :src="product.imgUrl" class="product-img" mode="aspectFit"></image>
    <text>{{ product.name }}</text>
    <view class="product-info">
      <text>价格:{{ product.price }}</text>
      <text>库存:{{ product.stock }}</text>
    </view>
    <text>{{ product.description }}</text>
  </view>
</template>

<script>
  export default {
    data() {
      return {
        product: {
          id: 1,
          imgUrl: 'http://example.com/product1.jpg',
          name: '商品1',
          price: 100,
          stock: 10,
          description: '这是商品1的描述信息。'
        }
      }
    }
  }
</script>

<style scoped>
  .product-img {
    width: 300rpx;
    height: 300rpx;
  }

  .product-info {
    display: flex;
    justify-content: space-between;
  }
</style>

In the above code, we use the dc0870658837139040642baa5555a380 and 28f128881ce1cdc57a572953e91f7d0f components Display information such as product pictures, name, price, inventory, and description.

3. Develop list pages and detail pages
When developing list pages and detail pages in UniApp, we can use the component development method of Vue.js. The list page and details page can be encapsulated into a component respectively and referenced where needed. The following is an example that shows how to develop list page and detail page components:

<!-- 列表页组件 -->
<template>
  <view>
    <navigator v-for="product in productList" :url="'/pages/detail?id=' + product.id">
      <image :src="product.imgUrl" class="product-img" mode="aspectFit"></image>
      <text>{{ product.name }}</text>
      <view class="product-info">
        <text>价格:{{ product.price }}</text>
        <text>库存:{{ product.stock }}</text>
      </view>
    </navigator>
  </view>
</template>

<script>
  export default {
    props: {
      productList: {
        type: Array,
        default: () => []
      }
    }
  }
</script>

<style scoped>
  .product-img {
    width: 200rpx;
    height: 200rpx;
  }

  .product-info {
    display: flex;
    justify-content: space-between;
  }
</style>
<!-- 详情页组件 -->
<template>
  <view>
    <image :src="product.imgUrl" class="product-img" mode="aspectFit"></image>
    <text>{{ product.name }}</text>
    <view class="product-info">
      <text>价格:{{ product.price }}</text>
      <text>库存:{{ product.stock }}</text>
    </view>
    <text>{{ product.description }}</text>
  </view>
</template>

<script>
  export default {
    props: {
      product: {
        type: Object,
        default: () => ({})
      }
    }
  }
</script>

<style scoped>
  .product-img {
    width: 300rpx;
    height: 300rpx;
  }

  .product-info {
    display: flex;
    justify-content: space-between;
  }
</style>

In the above code, we encapsulate the list page and detail page into List and Detail respectively component and pass data through props. The list page component accepts an array named productList, and the details page component accepts an object named product.

4. Summary
Through the above design and development guidelines, we can easily implement the design and development of list pages and details pages in UniApp. First determine the data displayed in the list and the display method, then design the components of the list page and details page respectively, and pass the data through props. Finally, we can display more product information or customize interactive effects according to actual needs. I hope this article will be helpful to everyone in UniApp application development!

The above is the detailed content of UniApp Design and Development Guide for Implementing List Pages and Details Pages. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn