ホームページ >ウェブフロントエンド >jsチュートリアル >WeChatミニプログラムで左右のスライドを実現する方法

WeChatミニプログラムで左右のスライドを実現する方法

亚连
亚连オリジナル
2018-06-20 15:40:122762ブラウズ

この記事では主にWeChatアプレットの左右スライドの実装コードを紹介します。非常に優れており、必要な友達は参考にしてください

あなたはもう一人ではありません。 あなたがプログラマーであろうとプログラマーであろうと、あなたが毎日行うことはコーディングまたはコーディングです。コーディングでは解決できない問題がある場合(頭の中でどのような問題に答えられないのか)、Tantan がお手伝いします。あなたがそれらを解決します。最近、インターネット上で「タンタン」という出会い系ソフトが流行しています(YPソフトだそうです)。画像を閲覧するだけで触ったことのない元タンタンのベテランプレイヤーであり、フロントエンド大好き女子の私もこのアプリを真似してみることにしました。 Zhijiが開発したものなので、アプリ全体のテーマスタイルが私のお気に入りの究極の女の子ファンに変更されたことは間違いありません、一緒にTantanの魅力を感じましょう〜

プロジェクトの全体的な効果

プロジェクトのいくつかの機能ポイントの分析ボタンの変更に対応してホームページの画像を左右にスワイプします

まず、私が最も興奮していることについて話しましょう。問題は、メインページの左右のスライドイベントとそれに対応するボタンがそれに応じて変化することです。つまり、画像の下の灰色のボタンまで左にスライドすると、そこにあります。は対応するアニメーション効果になり、右にスライドすると画像の下の赤いボタンに対応します。ミニプログラムのピットに入ったばかりの女の子にとって、マスターの指導がなければ、ロジックのピットから抜け出すのにどれくらい時間がかかるかわかりません。専門家の指導を受けて、この機能を完璧に実現しました。

ここに写真とテキスト情報を保存するための 3 つの大きなボックスがあり、それらをスワイパー アイテム内に置き、スワイパー コンポーネントを使用してボックス全体の左右のスライドを実現します

<swiper class=&#39;swiper-item__content&#39; current="" bindchange="changeswiper">
 <swiper-item class="swip">
  <view class=&#39;page__bd_content&#39;> 
   <image class="slide-image" src="http://pic.qqtn.com/up/2017-12/15126388387704237.jpg" mode="scaleToFill"/> 
   <view class="name">K</view>
   <view class="age">♂21</view>
   <view class="conste">金牛座</view>
   <view class="status">文化/教育</view> 
  </view>
 </swiper-item>
</swiper>

ボックスの下にはボタンがありません, 写真を2枚載せます。

<view class="page__ft">
 <image class="notlike {{left?&#39;active&#39;:&#39;&#39;}}" src="../../images/notlike.png" />
 <image class="like {{right?&#39;active&#39;:&#39;&#39;}}" src="../../images/like.png" />
 </view>

まずスライド時にトリガーされるアニメーション効果を記述します

.active {
 animation: active 1s ease;//定义一个叫做active的动画
}
@keyframes active {//补充active动作脚本
 0% {
  transform: scale(0.8);
 }
 50% {
  transform: scale(1.2);
 }
 100% {
  transform: scale(1.0);
 }
}

ページのデータに3つの変数を定義し、左右の変数を対応する画像にバインドします

data: {
 left: false ,
 right: false,
 activeIndex: 0
},

スワイパーバインディングイベントで具体的な判断を行いますLeft右スライドイベント

changeswiper: function(e) {
 var index = e.detail.current;//当前所在页面的 index
 if(index > this.data.activeIndex) {//左滑事件判断
  this.setData({
  left: true//若为左滑,left值为true,触发图片动画效果
  })
 } else if(index < this.data.activeIndex) {//右滑事件判断
  this.setData({
  right: true//若为右滑,right值为true,触发图片动画效果
  })
 }
 setTimeout(() => {//每滑动一次,数据发生变化
  this.setData({
  activeIndex: index,
  left:false,
  right:false
  })
 }, 1000);
 },

ローカルから画像をアップロード

まず、画像をアップロードしたい場所のsrcにデータ変数をバインドします

<image class="addImg" src="{{imgUrl}}" bindtap="uploadImg" />

画像のデフォルトのアドレスを入力します。つまり、画像をアップロードする前に画像を追加します

data: {
 imgUrl: &#39;../../images/addImg.png&#39;
 },

タップイベントをバインドして、アップロードされた画像のアドレスを置き換えます

uploadImg: function(e) {
var that = this;
wx.chooseImage({
 count: 1, //上传图片数量
 sizeType: [&#39;original&#39;, &#39;compressed&#39;], // 可以指定是原图还是压缩图,默认二者都有
 sourceType: [&#39;album&#39;, &#39;camera&#39;], // 可以指定来源是相册还是相机,默认二者都有
 success: function (res) {// 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
  var tempFilePaths = res.tempFilePaths;
  that.setData({
   imgUrl: tempFilePaths
 })
  wx.showToast({//显示上传成功
   title: &#39;上传成功&#39;,
   icon: &#39;success&#39;,
   duration: 2000
 })
 }
}),

ペアリング成功リストデータは、easy-mockを通じてバックグラウンドデータを取得します

block wx :for は複数のノードを含む構造ブロックをレンダリングします

<swiper-item>
 <view class="swiper-item__content">
  <block wx:for="{{friendsList}}" wx:key="index">
   <view class="weui-tab__content">
    <view class="weui-media-box__hd">
     <image src="{{item.avatar}}" mode="aspectFit"></image>
    </view> 
    <view class="weui-media-box__bd">
     <view class="weui-media-box__nickname">{{item.nickname}}</view>
     <view class="weui-media-box__message">{{item.message}}</view>
    </view>
   </view>
  </block>
 </view>
</swiper-item>

背景データを取得します

wx.request({
  url: &#39;https://www.easy-mock.com/mock/5a23dbf382614c0dc1bebf04/getFriendsList/getFriendsList&#39;,
  success: (res) => {
  // console.log(response);
  this.setData({
   friendsList: res.data.data.friendsList
  })
  }
 })

残りは個人的な理由で、weui の公式スタイルに慣れていません。自分で努力するので、優しいのは苦手ですが、まだまだ勉強中です~~~

以上、あなたのためにまとめてみましたので、今後のお役に立てれば幸いです。

関連記事:

node.jsのルーティングとミドルウェアの詳細な紹介

Vueで入場/退出アニメーションを実装する方法

webpackで実行されるentry関数の詳細な解釈

解決策Bootstrap モーダル ボックス送信バグ

以上がWeChatミニプログラムで左右のスライドを実現する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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