ホームページ >ウェブフロントエンド >htmlチュートリアル >ミニプログラム開発の実践的な経験を共有する

ミニプログラム開発の実践的な経験を共有する

零下一度
零下一度オリジナル
2017-06-24 11:42:191760ブラウズ

電子商取引の下部ナビゲーションバーの作成

一般に、電子商取引の下部ナビゲーションバーには、次のホームページ、カテゴリ、ショッピングカート、パーソナルセンターがあります。

app.json は、ページのパスとナビゲーション バーの属性を構成するために使用されます。ホームページ、カテゴリ、ショッピング カート、パーソナル センターのインターフェイスを作成する場合は、これらのインターフェイスもページに追加する必要があります。 app.json 次のコードを追加し、ページ パスを記述すると、システムが自動的にインターフェイスを作成します

  "pages":["pages/home/home","pages/classify/classify",  "pages/cart/cart","pages/mine/mine","pages/index/index"
  ],

さて、4 つのインターフェイスが追加されました。今日は、下部のナビゲーション バーをどのように作成しますか? app.json にナビゲーション バーを設定し、次のコードを app.json

 "tabBar": {"color": "#858585","selectedColor": "#f0145a","backgroundColor": "#ffffff","borderStyle": "#000","list": [
      {"pagePath": "pages/home/home","iconPath": "images/bottomNav/home.png","selectedIconPath": "images/bottomNav/home_select.png","text": "首页"
      },
      {"pagePath": "pages/classify/classify","iconPath": "images/bottomNav/classify.png","selectedIconPath": "images/bottomNav/classify_select.png","text": "分类"
      },
      {"pagePath": "pages/cart/cart","iconPath": "images/bottomNav/cart.png","selectedIconPath": "images/bottomNav/cart_select.png","text": "购物车"
      },
      {"pagePath": "pages/mine/mine","iconPath": "images/bottomNav/mine.png","selectedIconPath": "images/bottomNav/mine_select.png","text": "我的"
      }
    ]
  }

tabBar に追加できます。システムには独自のフィールドがあり、変更できないことをシステムに伝えます。ナビゲーション バーを追加する Color、selectedColor、backgroundColor は文字通りフィールドの意味もあり、対応する属性はデフォルトのフォントの色、チェックされたフォントの色、および背景色です。下部のナビゲーション バーとインターフェイスの間の境界線を定義する borderStyle に注目します。このプロパティは少し特殊です。この境界線が不要な場合は、残りのプロパティを白に設定できます。何を書くかは問題ではありません。この境界線を追加する必要があることは誰もが理解しています。信じられない場合は、試してみてください。 list 属性は当然、対応するナビゲーション バーを設定するためのインターフェイスです。

  • pagePath: ページ パス。ページに記述するパスです。

  • iconPath: デフォルトのナビゲーション バーの画像パス

  • selectedIconPath : 選択した画像のパス

  • text: ナビゲーション バーの名前

ここで言いたいのは、画像のパスは正しく書かれていなければならず、そうでないと画像が見つからない場合には表示されないということです。 これが私のナビゲーションです。バー画像--- 抽出コード: 8zwe 以下に示すように、画像のパスに従って対応するフォルダーを作成できます


1-1.png

注:

  • tabBarを追加するときは忘れないでください、上記のカンマを忘れないでください。これは各属性を区別するために使用されるため、属性を追加するたびに、これに注意してください。そうしないと、エラーが報告されます。一般に、エラー ログ「EOF」XXXXXXXXX と get STRING はすべて構文エラーであるため、どこが欠落しているかを注意深く確認してください。


    1-2.png
  • また、.json ファイルにはコメントを書き込むことができず、本来は読者が読みやすいようにいくつかのコメントを追加したかったのですが、次のエラー メッセージが表示されます。とても簡単です。コメントを削除するだけです


    1-3.png

    1つの例を他のケースに適用してください

  1. 4つのナビゲーションバーを作成しましたので、さらに2つのナビゲーションバーを追加したい場合は、大丈夫ですか?
    とても簡単だと思うかもしれません。リストに 2 つ追加してみてください。私も同じことをしましたが、問題が発生しました。システムはエラーを報告しますが、最大値は 5 つまでです。WeChat を最大値に設定したのは 5 つだけです。


    1-3.png
  2. ナビゲーションバーのデフォルトのホームページのチェックが赤になっていることに気づいたかどうかわかりませんが、カテゴリのデフォルトのチェックを赤にしたいのですが、どうすればいいですか?
    これは少し難しいです。私が最初に考えたのは、tabBar 属性のリストの最初の home 属性とclassify 属性を変更すれば問題が解決するはずだということでした。しかし、これは当てはまらず、実際にはそうではありませんでした。これは後で偶然見つけたものですが、ページの最初のパスがデフォルトのチェックとして分類されていることに気づきましたか?ホーム パスを変更し、pages 属性でパスを分類し、保存して再コンパイルするだけで、必要な効果が得られます。ここで要約できることの 1 つは、tabBar が の最初の行へのパスであるということです。のデフォルトのチェック オプションとしてのページ。

Eコマースのトップナビゲーションバーの制作

ナビゲーションバーについて話しましたが、今日はもう少し説明してから、トップナビゲーションバーの作り方、最初にレンダリングを教えましょう


2-1.png


这个导航栏可不像底部导航栏啦,因为他的级别比较低,是页面级别的导航栏,所以要写在页面里,你想要在哪个页面加入顶部导航栏就在哪个页面里添加如下代码,这里以首页的界面为例:
home.wxss

/* pages/home/home.wxss */page{  
  display: flex;  
  flex-direction: column;  
  height: 100%;  
}  
.navbar{  
  flex: none;  
  display: flex;  
  background: #fff;  
}  
.navbar .item{  
  position: relative;  
  flex: auto;  
  text-align: center;  
  line-height: 80rpx;  
  font-size:14px;
}  
/* 顶部导航字体颜色 */.navbar .item.active{  
  color: #f0145a;  
}  
/* 顶部指示条属性 */.navbar .item.active:after{  
  content: "";  
  display: block;  
  position: absolute;  
  bottom: 0;  
  left: 0;  
  right: 0;  
  height: 6rpx;  
  background: #f0145a;  
}

home.wxml

<!--导航条-->  
<view class="navbar">  
  <text wx:for="{{navbar}}" data-idx="{{index}}" class="item {{currentTab==index ? &#39;active&#39; : &#39;&#39;}}" wx:key="unique" bindtap="navbarTap">{{item}}</text>  
</view>

在home.wxml里面bindtap字段我们已经讲解过啦,是事件监听的标识符,事件名称叫“navbarTap”可以到home.js里查找到这个事件wx:for这个字段重点讲解,在组件上使用wx:for控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。默认数组的当前项的下标变量名默认为index,数组当前项的变量名默认为item,这是官方解释,说白了就是item默认叫做变量的值,index表示第几个变量的值,还不太明白请看这个 微信 wx:for 的讲解

  • wx:for="{{navbar}}" 意思是虚幻navbar的数组数据

  • {{item}} 这里面是navbar数组里面的值,如护肤、彩妆等值

  • wx:key="unique" 来指定列表中项目的唯一的标识符

  • data-idx="{{index}}" 存储一些数据供home.js里调用,这里data-xxx,xxx就是你给home.js里提供的数据关键词,home.js通过获取xxx关键词来获取xxx里面的数据

home.js

// pages/home/home.jsvar app = getApp()
Page({  data: {navbar: [&#39;护肤&#39;, &#39;彩妆&#39;, &#39;香水&#39;,&#39;个人护理&#39;],currentTab: 0,
  },  // 导航切换监听
  navbarTap: function (e) {console.debug(e);this.setData({      currentTab: e.currentTarget.dataset.idx
    })
  },

})

home.js,这里读过微信小程序入门篇(二)都知道,page页面里.js一般是放data数据和事件监听的,这里data有一个navbar导航栏数据,还有一个记录当前位置的currentTab,字段可以自由命名,赋值的时候对应上就好,

  • navbarTap 记得在home.wxml里面data-idx属性吗,在这里用到,currentTab: e.currentTarget.dataset.idx 把当前用户选择的Tab传给currentTab里,为了验证一下结果,我在这里面加入了一个输出日志console.debug(e);,可以在控制台上看输出的日志,我选择点击彩妆,输出台的数据idx:1刚好是彩妆的位置。


2-2.png

总结

今天我们讲解的微信小程序的底部导航栏和顶部导航栏,导航栏应该说是必须的对于电商小程序来说,那么今天的导航栏教程你掌握了吗?

学习过程中遇到什么问题或者想获取学习资源的话,欢迎加入学习交流群

以上がミニプログラム開発の実践的な経験を共有するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。