小程序-寫一個彈窗輸入組件

寫項目的時候發(fā)現(xiàn)小程序沒有自帶的彈窗輸入的組件埃难,只能自己寫一個癞埠。

1.半透明的遮蓋層

遮蓋層的樣式和顯隱事件
wxml代碼:

<view class="body">
  <button bindtap='eject'>彈窗</button>
</view>
<view class="model" catchtouchmove='preventTouchMove' wx:if='{{showModal}}'></view>

wxss代碼:

.model{
  position: absolute;
  width: 100%;
  height: 100%;
  background: #000;
  z-index: 999;
  opacity: 0.5;
  top: 0;
  left:0;
}

js代碼:

 /**
   * 頁面的初始數(shù)據(jù)
   */
  data: {
    showModal: false,
  },

  /**
   * 控制遮蓋層的顯示
   */
  eject:function(){
    this.setData({
      showModal:true
    })
  }
2.彈窗窗口實現(xiàn)

彈窗窗口的樣式和顯隱事件
wxml代碼:

<view class="modalDlg" catchtouchmove='preventTouchMove' wx:if='{{showModal}}'>
  <view class='windowRow'>
    <text class='userTitle'>標(biāo)題
  </text>
    <view class='back' bindtap='back'>
      返回
    </view>
  </view>
  <view class='wishName'>
    <input bindinput='wish_put' placeholder='請輸入內(nèi)容' class='wish_put'></input>
  </view>
  <view class='wishbnt'>
    <button class='wishbnt_bt' bindtap='ok'>確定</button>
  </view>
</view>

wxss代碼:

.modalDlg{
  width: 70%;
  position: fixed;
  top:350rpx;
  left: 0;
  right: 0;
  z-index: 9999;
  margin: 0 auto;
  background-color: #fff;
  border-radius: 10rpx;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.windowRow{
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  height: 110rpx;
  width: 100%;
}

.back{
  text-align: center;
  color: #f7a6a2;
  font-size: 30rpx;
  margin: 30rpx;
}

.userTitle{
  font-size: 30rpx;
  color: #666;
  margin: 30rpx;
}

.wishName{
  width: 100%;
  justify-content: center;
  flex-direction: row;
  display: flex;
  margin-bottom: 30rpx;
}

.wish_put{
  width: 80%;
  border: 1px solid;
  border-radius: 10rpx;
  padding-left: 10rpx;
}

.wishbnt{
  width: 100%;
  font-size: 30rpx;
  margin-bottom: 30rpx;
}


.wishbnt_bt{
  width: 50%;
  background-color: #f7a6a2;
  color: #fbf1e8;
  font-size: 30rpx;
  border: 0;
}

js代碼:

/**
   * 頁面的初始數(shù)據(jù)
   */
  data: {
    showModal: false,
    textV:''
  },

  /**
   * 控制顯示
   */
  eject:function(){
    this.setData({
      showModal:true
    })
  },

  /**
   * 點擊返回按鈕隱藏
   */
  back:function(){
    this.setData({
      showModal:false
    })
  },

  /**
   * 獲取input輸入值
   */
  wish_put:function(e){
    this.setData({
      textV:e.detail.value
    })
  },

  /**
   * 點擊確定按鈕獲取input值并且關(guān)閉彈窗
   */
  ok:function(){
    console.log(this.data.textV)
    this.setData({
      showModal:false
    })
  }
3.完整代碼

最后獻(xiàn)上完整代碼,有點啰嗦了珍语,想盡量詳細(xì)點
wxml代碼:

<view class="body">
  <button bindtap='eject'>彈窗</button>
</view>
<view class="model" catchtouchmove='preventTouchMove' wx:if='{{showModal}}'></view>
<view class="modalDlg" catchtouchmove='preventTouchMove' wx:if='{{showModal}}'>
  <view class='windowRow'>
    <text class='userTitle'>標(biāo)題
  </text>
    <view class='back' bindtap='back'>
      返回
    </view>
  </view>
  <view class='wishName'>
    <input bindinput='wish_put' placeholder='請輸入內(nèi)容' class='wish_put'></input>
  </view>
  <view class='wishbnt'>
    <button class='wishbnt_bt' bindtap='ok'>確定</button>
  </view>
</view>

wxss代碼:

.body{
  width: 100%;
  height: 100%;
  background-color: #fff;
  position: fixed;
  display: flex;
}

.body button{
  height: 100rpx;
}

.model{
  position: absolute;
  width: 100%;
  height: 100%;
  background: #000;
  z-index: 999;
  opacity: 0.5;
  top: 0;
  left:0;
}

.modalDlg{
  width: 70%;
  position: fixed;
  top:350rpx;
  left: 0;
  right: 0;
  z-index: 9999;
  margin: 0 auto;
  background-color: #fff;
  border-radius: 10rpx;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.windowRow{
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  height: 110rpx;
  width: 100%;
}

.back{
  text-align: center;
  color: #f7a6a2;
  font-size: 30rpx;
  margin: 30rpx;
}

.userTitle{
  font-size: 30rpx;
  color: #666;
  margin: 30rpx;
}

.wishName{
  width: 100%;
  justify-content: center;
  flex-direction: row;
  display: flex;
  margin-bottom: 30rpx;
}

.wish_put{
  width: 80%;
  border: 1px solid;
  border-radius: 10rpx;
  padding-left: 10rpx;
}

.wishbnt{
  width: 100%;
  font-size: 30rpx;
  margin-bottom: 30rpx;
}


.wishbnt_bt{
  width: 50%;
  background-color: #f7a6a2;
  color: #fbf1e8;
  font-size: 30rpx;
  border: 0;
}

js代碼:

Page({

  /**
   * 頁面的初始數(shù)據(jù)
   */
  data: {
    showModal: false,
    textV:''
  },

  /**
   * 控制顯示
   */
  eject:function(){
    this.setData({
      showModal:true
    })
  },

  /**
   * 點擊返回按鈕隱藏
   */
  back:function(){
    this.setData({
      showModal:false
    })
  },

  /**
   * 獲取input輸入值
   */
  wish_put:function(e){
    this.setData({
      textV:e.detail.value
    })
  },

  /**
   * 點擊確定按鈕獲取input值并且關(guān)閉彈窗
   */
  ok:function(){
    console.log(this.data.textV)
    this.setData({
      showModal:false
    })
  }
})
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末顽铸,一起剝皮案震驚了整個濱河市端盆,隨后出現(xiàn)的幾起案子合蔽,更是在濱河造成了極大的恐慌,老刑警劉巖介返,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拴事,死亡現(xiàn)場離奇詭異沃斤,居然都是意外死亡,警方通過查閱死者的電腦和手機刃宵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門衡瓶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人牲证,你說我怎么就攤上這事哮针。” “怎么了坦袍?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵十厢,是天一觀的道長。 經(jīng)常有香客問我捂齐,道長蛮放,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任奠宜,我火速辦了婚禮包颁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘压真。我一直安慰自己娩嚼,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布滴肿。 她就那樣靜靜地躺著岳悟,像睡著了一般。 火紅的嫁衣襯著肌膚如雪嘴高。 梳的紋絲不亂的頭發(fā)上竿音,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天,我揣著相機與錄音拴驮,去河邊找鬼春瞬。 笑死,一個胖子當(dāng)著我的面吹牛套啤,可吹牛的內(nèi)容都是我干的宽气。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼潜沦,長吁一口氣:“原來是場噩夢啊……” “哼萄涯!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起唆鸡,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤涝影,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后争占,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體燃逻,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡序目,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了伯襟。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片猿涨。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖姆怪,靈堂內(nèi)的尸體忽然破棺而出叛赚,到底是詐尸還是另有隱情,我是刑警寧澤稽揭,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布俺附,位于F島的核電站,受9級特大地震影響淀衣,放射性物質(zhì)發(fā)生泄漏昙读。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一膨桥、第九天 我趴在偏房一處隱蔽的房頂上張望蛮浑。 院中可真熱鬧,春花似錦只嚣、人聲如沸沮稚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蕴掏。三九已至,卻和暖如春调鲸,著一層夾襖步出監(jiān)牢的瞬間盛杰,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工藐石, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留即供,地道東北人。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓于微,卻偏偏與公主長得像逗嫡,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子株依,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,577評論 2 353

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