『壹』 在微信小程序中如何製作貓眼電影
有用戶喜歡看電影有喜歡玩微信小程序,今天小編就給大家帶來了在微信小程序中製作貓眼電影的詳細步驟,感興趣的小夥伴就趕緊和小編一起來看看吧。
正文
廢話不多說,先上效果圖
效果圖
本demo完成共耗費近兩周,也是在空餘時間去寫的,因為涉及到新知識JS、HTML和CSS3,所以也是邊學習邊寫,代碼編寫上有什麼不當處,還需小夥伴在評論處指明,幫助作者更上一層樓!
(註:本文章已默認各位小夥伴已經熟悉微信小程序的目錄結構以及每個文件所代表的的含義和小程序API的使用,所以文中不會詳細說明,結尾會直接給出完整代碼)
貓眼電影api:點擊此處
一、目錄結構
目錄結構
採用的開發工具是Egret Wing(點擊進入官網下載),主要目錄說明:
從目錄可知整體結構簡單,主要就是三個界面:首頁homepage、電影詳情頁moviedetail、影院列表頁cinema。
二、首頁
首頁
tab代碼,打開app.json如圖:
pages和tabBar
這里我想說下,微信小程序自帶對tabBar選擇效果作者還是挺喜歡的(如果在Android上還要給每個tab寫個selector選擇器的XML文件)由於這段沒什麼技術難點,所以就不多說了。
接下來進入首頁homepage,一個界面的文件結構離不開三個文件:xxx.js、xxx.wxml、xxx.wxss
先來看看布局代碼:
在這里作者承認當初寫的時候偷了下懶,有些標簽屬性我直接用style寫了,但真正開發時,最好把每個標簽的style寫在.wxss文件里,通過自定義的class名稱(或者id),相同布局的地方可以直接引用同一個class就可以了,不然會像作者這樣有些屬性重復寫了幾次(手動尷尬)。
.js代碼往下看:
homepage.js
電影列表的信息本放到了定義的infos[]數組中,小程序也不存在json解析,在wx.request請求下得到的res取相應的值res.data.data.movie,直接在homepage.html標簽中用wx:for={{infos}}遍歷,元素默認為item,取值的時候用item.值的名稱就可以取到數據。
這里有個小地方需要說明下,當時為了解決也是花了點時間:在json數據里有個參數名稱為3d,而且這個標簽不是所有電影都有的,所以定義了threeD:true這個變數,為了能在.wxml中取到值,就可想而知的直接寫成了wx:if={{item.3d}},結果就報錯了:
錯誤信息
問題就出在這個3d上,後來查資料才得知改寫成wx:if={{item['3d']}}就立馬解決啦,沒什麼原因,約定俗成,只是作者這只前端小白不知道而已(莫見怪......手動微笑)
為了讓大家更清楚了解電影列錶快的布局,作者畫了個草圖(真的很草......):
電影列表布局
發個牢騷:第一次寫布局時心裡就想,還是Android布局寫起來方便,剛開始接觸CSS3時覺得好麻煩,這個class要給個style,那個也要給個,而且有時要設置id,在同一個class下不同的id也要在wxss給個style,現在適應後感覺還算良好了。因為布局參數沒難點,所以這里就不貼代碼了。
二、詳情頁
電影詳情頁
這里不貼全部代碼了,只用關鍵代碼說明下當時遇到的幾個問題:
①高斯模糊
高斯模糊
這里共有兩個,一個class=blur(高斯模糊背景),一個class=info(電影信息)。剛開始是本著Android的布局設計思維去寫這個布局,這不就是個RelativeLayout嗎,寫著寫著到最後效果出來,發現作者還是太天真,信息那一欄我莫名其妙寫到高斯模糊的下面了,也就是寫成了LinearLayout且orientation=vertical,當時就笑自己:你現在又不是在寫Android,醒醒!孩子~主要原因是CSS3的知識不夠,所以我就老老實實去學習了一番,下面便是代碼:
高斯模糊和絕對布局
filter:blur(30px)和-webkit-filter:blur(30px)形成了高斯模糊的效果(內心OS:如果是Android的話又是一大堆代碼)。info中的position:relative、z-index:1,blur中的position:absolute、z-index:0相結合就能展示出上面的效果,關鍵在於info中的z-index要大於blur的,表示顯示在blur的上方,還要保證info是相對的,blur是絕對的,感興趣並且沒接觸過CSS3的盆友可以下載代碼自己去試試改改看看效果,不要像作者一樣以為自己會反而是自作聰明。
②點擊顯示全部
點擊圖標顯示全部
這里本猿又要贊揚一下三元運算符了:
影片簡介
.js文件中在data里設置三個變數
參數
showall方法
showall方法
hideText布爾值用來判斷當前是否為隱藏狀態,用style={{hideText?'-webkit-line-clamp:3':' '}}設置顯示行數,當hideText為true是顯示3行,否則不給值,即默認。定義hideClass來控制箭頭的指向,down表示當前簡介為隱藏,up表示顯示了全部,對於圖標旋轉這里只需給個旋轉屬性就行
箭頭180旋轉
好了,在詳情頁中花的時間比較多的就在這兩處了,還是那句老話:不明白的多去查找些資料。
評論部分就是簡單的列表,這里不再詳細說明。
三、電影院列表
影院列表
這里只是簡單的列出信息就行了,在布局上沒難點,不過代碼可以優化下,為了省事所以就沒去寫了,就簡單為了實現下效果。
今天的內容就和大家介紹到這里了,想要了解更多精彩內容請繼續關注我們!