ホームページ > ウェブフロントエンド > uni-app > リスト ページと詳細ページを実装するための UniApp 設計および開発ガイド

リスト ページと詳細ページを実装するための UniApp 設計および開発ガイド

王林
リリース: 2023-07-05 09:21:06
オリジナル
2999 人が閲覧しました

UniApp は、Vue.js に基づくクロスプラットフォーム開発フレームワークで、モバイル アプリケーション、小さなプログラム、H5 ページを迅速に構築できます。 UniApp では、リスト ページと詳細ページの設計と開発を実装することが非常に一般的な要件です。この記事では、UniApp でリスト ページと詳細ページを設計および開発する方法を紹介し、コード例を使用して説明します。

1. リストページのデザイン
リストページをデザインするときは、まずリストに表示するデータと表示方法を決める必要があります。以下は、製品リストを示す簡単な例です。

<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>
ログイン後にコピー

上記のコードでは、<navigator> コンポーネントを使用して、各製品をクリックすると詳細ページにジャンプすることを実現しています。 <image> コンポーネントと <text> コンポーネントを使用して、製品の写真、名前、価格、在庫、その他の情報を表示します。 v-for 命令を使用して productList 配列を走査し、複数の製品を表示します。

2. 詳細ページのデザイン
詳細ページには通常、単一の製品の詳細情報が表示されます。詳細ページをデザインするときに、製品の説明、仕様、レビューなど、実際のニーズに基づいてより多くの製品情報を表示できます。以下は、製品の詳細を示す簡単な例です。

<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>
ログイン後にコピー

上記のコードでは、<image> コンポーネントと <text> コンポーネントを使用します。製品の写真、名前、価格、在庫、説明など。

3. リストページと詳細ページの開発
UniApp でリストページと詳細ページを開発する場合、Vue.js のコンポーネント開発方法を使用できます。リスト ページと詳細ページはそれぞれコンポーネントにカプセル化され、必要に応じて参照できます。以下は、リスト ページと詳細ページのコンポーネントを開発する方法を示す例です。

<!-- 列表页组件 -->
<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>
ログイン後にコピー

上記のコードでは、リスト ページと詳細ページを ListDetail にカプセル化します。それぞれ コンポーネントを作成し、props を通じてデータを渡します。リスト ページ コンポーネントは productList という名前の配列を受け入れ、詳細ページ コンポーネントは product という名前のオブジェクトを受け入れます。

4. まとめ
上記の設計開発ガイドラインにより、UniApp でのリスト ページと詳細ページの設計と開発を簡単に実装できます。まず一覧に表示するデータと表示方法を決め、次に一覧ページと詳細ページのコンポーネントをそれぞれ設計し、propsにデータを渡します。最後に、実際のニーズに応じて、より多くの製品情報を表示したり、インタラクティブな効果をカスタマイズしたりできます。この記事が UniApp アプリケーション開発の皆様のお役に立てれば幸いです。

以上がリスト ページと詳細ページを実装するための UniApp 設計および開発ガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート