小程式開發記錄(一)

来源:https://www.cnblogs.com/yk0627/archive/2023/09/08/17686423.html
-Advertisement-
Play Games

寫在前面:初次嘗試小程式,在不使用框架的情況下,如果遇到問題,可以儘量去參考官方文檔 1.scroll-view組件 scroll-view是一個可滑動的組塊.需要設置其中具體的height高度,並且在標簽中設置scroll-y="true"; 1 <scroll-view class="sceol ...


寫在前面:初次嘗試小程式,在不使用框架的情況下,如果遇到問題,可以儘量去參考官方文檔

1.scroll-view組件

scroll-view是一個可滑動的組塊.需要設置其中具體的height高度,並且在標簽中設置scroll-y="true";

1 <scroll-view class="sceoll_style" scroll-y="true" bindscrolltolower='scrollToLower' lower-threshold='30'>
2 </scroll-view>

bindscrolltolower='scrollToLower',這一句是用來表示scroll觸底所觸發的事件,

觸底時間可以進行調用載入數據介面,並且這個數據介面一定是分頁訪問的,(後端不給分頁介面就幹不了嗷)

請求參數里 pageNum+1,然後拼接得到的數據數組.

lower-threshold='30',這一句是用來表示觸底距離的計算.

2.動態區分選中狀態

這裡是html設計

<view class="title_main">
  <view wx:for="{{conditionList}}" wx:for-item="oneitem" >
  <!--這裡動態顯示選中狀態-->
  <view class="chosetitle{{activeItem==oneitem.id?'_ischose':''}}" bindtap="SyntheSize" data-item="{{oneitem.id}}">
  {{oneitem.name}}</view>
  </view>
</view>

這裡是css文件

.title_main{
  padding-left: 15rpx;
  width: 100%;
  height: 150rpx;
  line-height: 150rpx;
  display: flex;
  background-color: rgb(0, 148, 0);
}
.chosetitle_ischose{
  font-weight:900;
  font-size: 16px;
  width: 180rpx;
  height: 150rpx;
  font-size: large;
  line-height: 150rpx;
  color: white;
  background-color:rgb(0, 114, 0) ;
  text-align: center;
}
.chosetitle{
  width: 180rpx;
  height: 150rpx;
  font-size: large;
  line-height: 150rpx;
  color: white;
  text-align: center;
}

JS中的業務設計

在JS中完成賦值,才能在html進行比對,並且產生差異的效果;

效果如圖: 

3.動態滑動加狀態區分

<!--訂單選項設計-->
<scroll-view class="Stytle_scroll" scroll-x="true" show-scrollbar="false">
  <view class="One_orderState" wx:for="{{conditionList}}" wx:for-item="title_item">
    <view class="One_orderState_item{{activeItem==title_item.id?'_ischose':''}}" data-id="{{title_item.id}}" bindtap="handoff_state">{{title_item.name}}</view>
  </view>
</scroll-view>

1. `<scroll-view class="Stytle_scroll" scroll-x="true" show-scrollbar="false">`:這是一個滾動視圖容器,用於在水平方向上滾動內容。`class`屬性用於設置CSS類名,以便樣式控制。`scroll-x="true"`屬性表示允許水平滾動,`show-scrollbar="false"`屬性表示隱藏滾動條。

2. `<view class="One_orderState" wx:for="{{conditionList}}" wx:for-item="title_item">`:這是一個視圖容器,其中包含了要迴圈渲染的一組視圖元素。`wx:for="{{conditionList}}"`指定了迴圈的數據源,`conditionList`是在小程式的數據綁定中定義的一個數組。`wx:for-item="title_item"`用於定義在每次迴圈中的當前項的別名,這裡的別名是`title_item`,你可以在迴圈內部使用它來訪問當前項的屬性。

3. `<view class="One_orderState_item{{activeItem==title_item.id?'_ischose':''}}" data-id="{{title_item.id}}" bindtap="handoff_state">{{title_item.name}}</view>`:這是迴圈渲染的視圖元素,它會根據`conditionList`數組中的數據項進行多次渲染。

- `class="One_orderState_item{{activeItem==title_item.id?'_ischose':''}}"`:這是一個視圖元素的CSS類名。根據條件判斷,它可能會附加`_ischose`類名,這取決於`activeItem`是否等於`title_item.id`,如果相等,則添加`_ischose`類名。

- `data-id="{{title_item.id}}"`:這是一個自定義的`data-*`屬性,用於存儲視圖元素的數據。在這裡,它存儲了`title_item.id`的值。

- `bindtap="handoff_state"`:這是一個點擊事件的綁定,當用戶點擊這個視圖元素時,會觸發名為`handoff_state`的事件處理函數。

- `{{title_item.name}}`:這是在視圖元素中顯示的文本內容,它來自於`title_item.name`,也是`conditionList`數組中的一部分數據。

綜合來說,這段代碼創建了一個水平滾動的視圖容器,其中包含了一組視圖元素,這些元素根據`conditionList`數組中的數據進行迴圈渲染。用戶可以點擊這些元素,觸發相應的事件處理函數。根據條件,某些元素可能會附加一個特定的CSS類名。

 3.時間篩選選擇

<!--時間篩選框-->
<view class="date_chose">
  <view class="chose_block">
    <text class="text_lable">開始:</text>
    <picker mode="date" value="{{startDate}}" start="1970-01-01" end="{{endDate}}" bindchange="bindStartDateChange">
      <view class="one_picker">{{startDate}}</view>
    </picker>
  </view>
  <view class="chose_block">
    <text class="text_lable">結束:</text>
    <picker mode="date" value="{{endDate}}" start="1970-01-01" end="{{today}}" bindchange="bindEndDateChange">
      <view class="one_picker">{{endDate}}</view>
    </picker>
  </view>
<view class="filter-button" bindtap="filterData">篩選</view> </view> <!--時間篩選框結束-->

1. `<view class="date_chose">`:這是一個視圖容器(`<view>`)的起始標簽,`class`屬性設置了CSS類名,用於樣式控制。這個容器包含了日期選擇器和篩選按鈕。

2. `<view class="chose_block">`:這是一個包含日期選擇器和文本標簽的子視圖容器,用於包裹“開始日期”的部分。

- `<text class="text_lable">開始:</text>`:這是一個文本標簽,顯示"開始:"這個文本,用於標識日期選擇器的作用。

- `<picker>`:這是一個日期選擇器組件,通過`mode`屬性設置為"date",表示選擇日期。`value`屬性用於綁定日期選擇器的值,`start`屬性設置了可選日期範圍的開始日期,`end`屬性設置了可選日期範圍的結束日期。

- `bindchange="bindStartDateChange"`:這個屬性指定了當用戶選擇日期後觸發的事件處理函數,通常用於處理日期選擇變化時的邏輯。

- `<view class="one_picker">{{startDate}}</view>`:這個`<view>`元素用於顯示選擇的開始日期,`{{startDate}}`是一個數據綁定,將日期選擇器的值綁定到這個視圖上,以便顯示用戶選擇的日期。

3. `<view class="chose_block">`:與前一個類似,但這個部分是用於選擇結束日期的。

4. `<view class="filter-button" bindtap="filterData">篩選</view>`:這是一個按鈕視圖,當用戶點擊它時,將觸發名為`filterData`的事件處理函數。用戶可以點擊這個按鈕來執行篩選操作。

綜合來說,這段代碼創建了一個包含兩個日期選擇器和一個篩選按鈕的用戶界面元素,允許用戶選擇起始日期和結束日期,然後點擊篩選按鈕來觸發篩選操作。日期選擇器的選擇結果將通過事件處理函數綁定到對應的數據變數中,以便在後續的邏輯中使用。


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

-Advertisement-
Play Games
更多相關文章
  • 本文分享自華為雲社區《GaussDB AP是如何執行SQL的》,作者:yd_270088468。 前言 介紹GaussDB AP各組件是如何協調工作的,會著重介紹SQL引擎。 1、SQL引擎組件和SQL生命周期 Parser: 詞法/語法分析模塊。詞法分析會從SQL字元串中解析出一個個單詞,作為語法 ...
  • GaussDB的遷移場景越來越多,也越來越複雜,所以我們會不斷地進行探索和創新,讓我們的方案更完善,遷移過程更平滑。 ...
  • SqlServer 單用戶解決方案 USE master; GO DECLARE @SQL VARCHAR(MAX); SET @SQL='' SELECT @SQL=@SQL+'; KILL '+RTRIM(SPID) - FROM master..sysprocesses WHERE dbid= ...
  • 在上一篇文章中,我們介紹了彈性資料庫連接失效的背景,並探討了HikariCP連接池探活策略的相關內容。在本文中,我們將會繼續探討另一個線上常用的連接池——Druid,併為您介紹如何在使用Druid時實現最佳實踐的彈性資料庫連接池探活策略。 ...
  • 原文地址:https://www.mssqltips.com/sqlservertip/3598/troubleshooting-transactional-replication-latency-issues-in-sql-server/ 問題 我安裝了幾個SQL Server 2012實例的集群 ...
  • sidebar: auto # Android 調試橋 (adb) Android 調試橋 (adb) 是一種功能多樣的命令行工具,可讓您與設備進行通信。adb 命令可用於執行各種設備操作,例如安裝和調試應用。adb 提供對 Unix shell(可用來在設備上運行各種命令)的訪問許可權。它是一種客戶 ...
  • 在Service中使用系統dialog彈框,但是無法覆蓋全部,底部菜單依然可以被點擊,在某些場景下是不符合需求的 getDialog().getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ERROR); 顯然是 dialog 的層級 ...
  • # 什麼是Promise (含如何判斷一個值是Promise) > 本文旨在對 Promise 的規範進行解釋, 便於讀者在學習 Promise 的過程中梳理 Promise 之間的操作關係, 不對具體的代碼實現和Promise用法進行解釋. > > 比如, 為什麼 [[MDN-await]](ht ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...