小程序 筆記11.15

課堂學(xué)習(xí):添加數(shù)據(jù) 和 搜索

一、雙向綁定

model:value = '{{XXX}}'?

wxml里的內(nèi)容會和js中的同步

?<input?class="txt"?model:value='{{title}}'></input>

?js中 data:?{ title:''},兩者雙向綁定 title的值發(fā)生改變 則表單中的值也會同步改變

二奸披、picker 從底部彈起的滾動選擇器

?<!--?選擇器組件?range-key屬性指定選擇器中顯示的內(nèi)容?range屬性指定一個數(shù)組-->

????<picker?bindchange="bindPickerChange"?range-key?='Name'?range="{{sections}}">

??????<view?class="picker">

??????<!--?根據(jù)選擇器選中的索引缸榄,顯示對應(yīng)的名稱?-->

????????{{sections[sectionsActiveIndex].Name}}

??????</view>

????</picker>

三镜遣、添加數(shù)據(jù)方法

Page({

??/**

???*?頁面的初始數(shù)據(jù)

???*/

??data:?{

????//分類信息的數(shù)組

????scetions:[],

????//選中的分類項(xiàng)目的下標(biāo)

????sectionsActiveIndex:0,

????//題目標(biāo)題

????title:?'',

????//分類id

????section_id:?0,

????//答案

????answer:?'',

????//解析

????desc:?''

??},

??//分類選擇器改變選項(xiàng)方法

??bindPickerChange:?function(e)?{

????console.log(e)

????console.log(e.detail.value)

????//獲取分類的下標(biāo)

????let?index?=?e.detail.value

????this.data.section_id?=?this.data.sections[index].Id

????//更新選中的下標(biāo)

????this.setData({

??????sectionsActiveIndex?:?index

????})

??},

??//加載課程分類信息的方法

??async?loadSectioins()?{

????//發(fā)送請求獲取所有的課程分類

????let?data?=?await?wx.$get('Section/GetSections')

????//添加一個課程分類

????let?first?=?{Id:0,Name:'請選擇'}

????//將添加的分類添加到數(shù)組的第一位

????data.unshift(first)

????console.log(data)

????//渲染頁面?把獲取到的data給sections數(shù)組

????this.setData({

??????sections:?data

????})

??},

??//添加題目的方法

??async?addSubject()?{

????console.log(this.data.title)


????//如果?非空驗(yàn)證失敗?這里取反了?所以是truth?直接返回

????//根據(jù)下方所寫的代碼?如果有內(nèi)容為空?則checkInput返回的是?true?取反就是false?直接返回??如果有內(nèi)容?則checkInput返回truth?取反后為false?便不執(zhí)行return

????if(!this.checkInput())?{

??????return

????};

????let?{title,section_id,answer,desc}?=?this.data

????//提交用post

????let?r?=?await?wx.$post('Subject/AddSubject',?{

??????//?title:?this.data.title,??

??????title:title,

??????//?section_id:?this.data.section_id,??

??????section_id?:section_id,

??????//?answer:?this.data.answer,?

??????answer?:?answer,

??????//?desc:?this.data.desc??

??????desc?:?desc

????})

????console.log(r)

????if?(r)?{

??????wx.$msg('提交成功')

??????//清空頁面

??????this.clear()

????}

??},

??//?非空驗(yàn)證

??checkInput(){

????//如果他是空的?那就是truth??如果有值?取反就是false??

????if(!this.data.title){

??????wx.$msg('請輸入標(biāo)題')

????}else?if(this.data.section_id?==?0){

??????wx.$msg('請選擇分類')

????}else?if(!this.data.answer){

??????wx.$msg('請輸入答案')

????}?else?{

??????return?true

????}

????return?false

??},

??//清空數(shù)據(jù)的方法

??clear()?{

????this.setData({

??????//清空表單數(shù)據(jù)

??????title:?'',

??????section_id:?0,

??????answer:?'',

??????desc:?'',

??????//清空選擇器索引

??????sectionsActiveIndex:0

????})

??},

??/**

???*?生命周期函數(shù)--監(jiān)聽頁面加載

???*/

??onLoad:?function?(options)?{

????this.loadSectioins()

??}

})

四纳寂、搜索方法

<!--?搜索區(qū)?-->

<view?class="search">

??<input?placeholder='請輸入搜索關(guān)鍵字'?class="inp"?model:value?=?'{{title}}'?/>

??<view?class="txt"?bindtap="search"?>搜索</view>

</view>


??data:?{

????//課程題目數(shù)組

????subjects:?[],

????pageIndex:?1,

????pageSize:?10,

????title:?''

??},


??//搜索方法

??search()?{

????//將頁碼重新恢復(fù)成1

????this.data.pageIndex?=?1

????//數(shù)組里面的數(shù)據(jù)要清空

????this.data.subjects?=?[]

????//重新獲取數(shù)據(jù)

????this.loadSubjects()

??},

//加載課程對應(yīng)的題目信息的方法

??async?loadSubjects()?{

????let?data?=?await?wx.$get('Subject/GetSubjects',?{

??????//頁碼

??????pageIndex:?this.data.pageIndex,

??????//每頁數(shù)量

??????pageSize:?this.data.pageSize,

??????//data中加上一個參數(shù)?title?用于搜索方法使用?又this.data.title?和?搜索框input?的?value?雙向綁定?所以可以根據(jù)搜索框的內(nèi)容找title

??????title:this.data.title

????})

????if?(data.length?===?0)?{

??????//如果獲取不到數(shù)據(jù)了?就調(diào)用提示框的封裝函數(shù)

??????wx.$msg('沒有更多')

??????return

????}

????//把最新獲取的數(shù)據(jù)追加到數(shù)組的后面

????this.data.subjects.push(...data)

????this.setData({

??????//這樣是覆蓋?每次頁面加載都覆蓋之前的

??????//?subjects:?data

??????subjects:?this.data.subjects

????})

??}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末淘讥,一起剝皮案震驚了整個濱河市圃伶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蒲列,老刑警劉巖窒朋,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異蝗岖,居然都是意外死亡侥猩,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進(jìn)店門抵赢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來欺劳,“玉大人唧取,你說我怎么就攤上這事』幔” “怎么了枫弟?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長腔剂。 經(jīng)常有香客問我媒区,道長驼仪,這世上最難降的妖魔是什么掸犬? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮绪爸,結(jié)果婚禮上湾碎,老公的妹妹穿的比我還像新娘。我一直安慰自己奠货,他們只是感情好介褥,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著递惋,像睡著了一般柔滔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上萍虽,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天睛廊,我揣著相機(jī)與錄音,去河邊找鬼杉编。 笑死超全,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的邓馒。 我是一名探鬼主播嘶朱,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼光酣!你這毒婦竟也來了疏遏?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤救军,失蹤者是張志新(化名)和其女友劉穎财异,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體缤言,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡宝当,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了胆萧。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片庆揩。...
    茶點(diǎn)故事閱讀 40,675評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡俐东,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出订晌,到底是詐尸還是另有隱情虏辫,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布锈拨,位于F島的核電站砌庄,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏奕枢。R本人自食惡果不足惜娄昆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望缝彬。 院中可真熱鬧萌焰,春花似錦、人聲如沸谷浅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽一疯。三九已至撼玄,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間墩邀,已是汗流浹背掌猛。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留磕蒲,地道東北人留潦。 一個月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像辣往,于是被迫代替她去往敵國和親兔院。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評論 2 360

推薦閱讀更多精彩內(nèi)容

  • 課堂學(xué)習(xí):處理時間數(shù)據(jù) 上拉下拉頁面 一站削、處理時間戳 1.在后臺處理 //加載課程對應(yīng)的題目信息的方法 async...
    瑪騎犸閱讀 212評論 0 0
  • 1. 下載Vant Weapp 步驟一:通過 npm 安裝 npm i @vant/weapp -S --prod...
    一點(diǎn)都不神秘閱讀 2,831評論 0 0
  • 一坊萝、創(chuàng)建項(xiàng)目 1、準(zhǔn)備工作 微信公眾平臺注冊開發(fā)者賬號:https://mp.weixin.qq.com/[htt...
    一個想讀書的人閱讀 1,203評論 0 1
  • 微信小程序 一许起、創(chuàng)建項(xiàng)目 1十偶、準(zhǔn)備工作 微信公眾平臺注冊開發(fā)者賬號:https://mp.weixin.qq.co...
    元肖閱讀 472評論 0 2
  • 先先拋出結(jié)論:微信小程序就是一個類似RN的輪子猛频,可以快速開發(fā)狮崩,有一定的適用場景蛛勉,但是也有其局限性。(結(jié)論是基于微信...
    c14328d5898b閱讀 1,342評論 1 10