微信小程式-隱藏和顯示自定義的導航

来源:http://www.cnblogs.com/tongyi/archive/2017/06/13/7001147.html
-Advertisement-
Play Games

微信小程式中不能直接操作window對象,document文檔,跟html的樹結構不相同。 實現類似導航的隱藏顯示,如圖效果: 點擊網路顯示或隱藏網路中包含的內容。其他類似。 如果是jquery很方便實現,能直接操作document。在微信小程式中實現思路是:在邏輯層定義變數,通過setData賦值 ...


微信小程式中不能直接操作window對象,document文檔,跟html的樹結構不相同。

實現類似導航的隱藏顯示,如圖效果:

點擊網路顯示或隱藏網路中包含的內容。其他類似。

如果是jquery很方便實現,能直接操作document。在微信小程式中實現思路是:在邏輯層定義變數,通過setData賦值。

方法一:通過變數直接賦值,給每一個要控制顯示的view定義變數

.wxml 代碼:

<!--index.wxml-->
<view class="navView" bindtap="tigger" data-num="1">視圖容器</view>
<view class="classname" hidden="{{view1}}">
 <button bindtap="opentype" data-type="view">view</button>
 <button bindtap="opentype" data-type="movable">movable</button>
</view>

<view class="navView" bindtap="tigger" data-num="2">基礎內容</view>
<view class="classname" hidden="{{view2}}">
<button bindtap="opentype" data-type="icon">icon</button>
<button bindtap="opentype" data-type="text">text</button>
<button bindtap="opentype" data-type="progress">progress</button>
</view>

<view class="navView" bindtap="tigger" data-num="3">表單組件</view>
<view class="classname" hidden="{{view3}}">
<button bindtap="opentype" data-type="button">button</button>
<button bindtap="opentype" data-type="checkbox">checkbox</button>
<button bindtap="opentype" data-type="form">form</button>
<button bindtap="opentype" data-type="input">input</button>
<button bindtap="opentype" data-type="label">label</button>
<button bindtap="opentype" data-type="picker">picker</button>
<button bindtap="opentype" data-type="textarea">textarea</button>
</view>
View Code

.js對應代碼:

 data: {
    view1: true,
    view2: true,
    view3: true
  },
  opentype: function (e) {
    var url = e.currentTarget.dataset.type
    url = url + '/' + url
    wx.navigateTo({
      url: url
    })
  },

  tigger: function (e) {
    var num = e.currentTarget.dataset.num
    if (num == 1) {
      this.setData({
        view1: !this.data.view1
      })
    } else if (num == 2) {
      this.setData({
        view2: !this.data.view2
      })
    } else if (num == 3) {
      this.setData({
        view3: !this.data.view3
      })
    }
}
View Code

通過data-num="1" 這中傳值方式,設置對應的view1的值。

這種方法能夠實現效果,但是在添加了新的view之後需要修改js代碼,所以不是最優的方法。

方法二:

.wxml 代碼:

<!--index.wxml-->
<view class="navView" bindtap="tigger" data-num="0">網路</view>
<view class="classname" hidden="{{showArr[0]}}">
 <button bindtap="opentype" data-url="network/request/request">request</button>
</view>

<view class="navView" bindtap="tigger" data-num="1">上傳、下載</view>
<view class="classname" hidden="{{showArr[1]}}">
 <button bindtap="opentype" data-url="uploadFile">uploadFile</button>
 <button bindtap="opentype" data-url="downloadFile">downloadFile</button>
</view>


<view class="navView" bindtap="tigger" data-num="2">WebSocket</view>
<view class="classname" hidden="{{showArr[2]}}">
 <button bindtap="opentype" data-url="connectSocket">connectSocket</button>
 <button bindtap="opentype" data-url="downloadFile">OnSocketOpen</button>
</view>

<view class="navView" bindtap="tigger" data-num="3">媒體</view>
<view class="classname" hidden="{{showArr[3]}}">
 <button bindtap="opentype" data-url="uploadFile">圖片</button>
 <button bindtap="opentype" data-url="downloadFile">錄音</button>
</view>
View Code

.js對應代碼:

// index.js

var statusArrs = [false]

Page({

  /**
   * 頁面的初始數據
   */
  data: {
    showArr: statusArrs
  },
  opentype: function (e) {
    var url = e.currentTarget.dataset.url
    url = '../' + url
    wx.navigateTo({
      url: url
    })
  },
  //顯示隱藏
  tigger: function (e) {
    var that = this;
    var num = e.currentTarget.dataset.num
    statusArrs[num] = !statusArrs[num]
    that.setData({
      showArr: statusArrs
    })
  }
})
View Code

方法二這種方式就簡單實現了不修改js代碼,添加了新的view也能控制隱藏顯示。

一點小技巧分享。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一 第一種方法 在select 標簽的父標簽加上 data-tap-disabled=”true” 二 找到 ionic.bundle.js文件 下邊有個方法 function tapIgnoreEvent(e) { if (e.isTapHandled) return true; e.isTapH ...
  • 一,效果圖。 二,工程圖。 三,代碼。 RootViewController.h RootViewController.m ...
  • 一、自己封裝URLConnection 連接請求類 public void downloadFile1() { try{ //下載路徑,如果路徑無效了,可換成你的下載路徑 String url = "http://c.qijingonline.com/test.mkv"; String path = ...
  • Android學習筆記目錄 ...
  • 前不久 項目 終於成功發佈上線了,最近就在給項目做優化,併排除一些線上軟體的 bug,因為項目中使用了友盟統計,所以在友盟給出的錯誤信息統計中能比較方便的找出客戶端異常的信息,可是很多像數組越界卻只給出了 *** -[__NSArrayM objectAtIndex:]: index 50 beyo ...
  • //獲得當前時間並且轉為字元串 //獲取當前時間轉為時間戳 //13位時間戳1469193006001(毫秒)轉 系統時間2016-08-11 08:55:36 如果只獲取當前的年月日,用NSDate 直接截取是不對的,以下方法提供了獲取當前的年月日等等 ...
  • 一般在使用RecyclerView的時候不免要修改RecyclerView的數據,使用notifyDataSetChanged()來刷新界面,但是當數據比較多,而只是修改了一點的數據,或者刷新比較頻繁,這樣就會導致界面的卡頓問題,用戶交互特別不好。 這個時候就需要只是修改需要修改的數據,不要將數據全 ...
  • 首先看一個API:setMaskFilter(MaskFilter maskfilter): 設置MaskFilter,可以用不同的MaskFilter實現濾鏡的效果,如濾化,立體等。 以下有兩個MaskFilter的子類可供選擇: BlurMaskFilter:指定了一個模糊的樣式和半徑來處理Pa ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...