您好,登錄后才能下訂單哦!
這篇文章主要介紹了如何實現Linux命令查詢小程序,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
首先,先分享一下為什么要選擇 WePY ?
在項目開始進行選型的時候,我可選的底層框架有 WePy、MPVue、Taro、MinUI,這些框架都是工程化做得很好的框架,可以幫助小程序項目長期進行維護。其中,Taro 因為采用的是我所不熟悉的 React ,所以從一開始就被排除。MPVue 我看了以后,它更多是給 Web 開發者提供小程序轉化工具,而不是給小程序開發者提供類 Vue 工具,所以,也被我排除。 MinUI 由于其本身僅僅是提供了組件化的方案和 npm 、ES6/ES7 的支持,其他的命令依然要延續使用小程序的函數,并沒有提供更多的支持,整個生態尚不豐富,所以就又排除掉了 MinUI。
到***,我選擇了 WePY 。在下手之前,我研究了一下 WePY,來看看 WePY 中都有哪些優點。 總的來說,我認為 WePY 的優點如下:
提供了類似 Vue 的組件化方案:組件化開發可以提升項目的可維護程度,隨著你開發周期的變長,組件化會非常大的影響你的開發體驗。
提供了 ES6/ES7 語法的支持:JavaScript 為人詬病的回調在 ES6、ES7 中有了更加優雅的實現。
提供了 Vue 的生態:和 MinUI 的孤軍奮戰不同,WePY 有很多 Vue 社區生態的產品,比如 WePY-Redux、RxWX 等一系列 Vue 下,大家習慣使用的工具,這使得開發的流程更加順暢,開發體驗也更加一致。
對原生 API 的優化:在小程序官方提供的接口中,很多都是提供的回調模式,并不提供 Promise ,我們在使用時往往需要自己再重新包一層,比較麻煩。在 WePY 當中, WePY 官方幫我們封裝好了一層,你可以直接使用 WePY 所封裝好的方法,減少了封裝的工作量。
Vue 習慣的數據設定:在 WePY 中,你可以使用 this.xxx=xxx
的語法進行賦值操作,相比于原生的 setData 方法,有更加舒適的語法,可維護性也更高。
提供了 computed 方法:在開發小程序的時候,我們難免要對數據進行格式化,在傳統的小程序開發中,我們需要對數據進行 map ,再進行修改,但是用了 WePY 以后,我們可以使用 computed 計算屬性來進行數據的格式化和調整,大大的提升了代碼的可讀性。
上述是我所看重的 WePY 優勢,接下來,我來說一說如何在 WePY 中使用云開發。
我寫過很多小程序,也講過一些小程序課程,經常會有人問我,XXX 可以用在 XXX 里么,放在這個場景中,就是云開發可以用在 WePY 中么?
答案當然是肯定的。
看待這個問題,你應該首先搞清楚,云開發所提供的到底是什么?
云開發提供的是數據存儲、文件存儲和計算能力
和 WePY 的定位提供微信小程序組件化開發的能力并不沖突,所以, WePY 和云開發并不沖突,你可以在 WePY 中使用云開發。
由于 WePY 本身并沒有提供云開發的模板(不過你現在可以使用 wepy init cloudkits/wepy-tcb-demo
命令來初始化一個包含了云開發示例的 WePY 項目),所以,我們需要自己在項目中添加云開發。
云開發本身而言,是集成在 wx.
的名字空間內的,所以無需配置可以直接使用 wx.cloud.xxx
來調用云開發的各項命令。此外,比較特殊的是,你需要指定一下云函數目錄,來確保微信小程序開發者工具能夠識別出云函數目錄。
此處需要注意的是, 因為云開發的命令本身就支持 Promise 和 Callback ,所以你可以直接使用
wx.cloud
來調用,而不是使用wepy.cloud
來調用。WePY 官方也沒有針對云開發進行再一次的封裝。
你可以在小程序項目的根目錄創建一個新的目錄 cloudfunctions
,然后在 project.config.json
中添加一個新的配置項目 cloudfunctionRoot
,并將其值設置為 cloudfunctions
。這樣,微信小程序開發者工具就能夠識別出這個目錄是云函數的目錄,并為其加上特殊的目錄名。
此處需要注意的是,云函數應當放在小程序的源碼目錄
src
之外,不然會導致編譯報錯。我試圖尋找wepy.config.js
的中關于屏蔽編譯檢查目錄的配置項目,但是沒有找到,所以我直接將這個目錄放在了項目根目錄,云函數和小程序源碼的src
同級。
這樣,你就完成了 WePY 中的小程序·云開發的引用。
使用 WePY 開發時,我們使用 this.xxx
來修改數據的值,但是在我一開始開發的時候,遇見的***個問題時,使用 this.xxx
無法設置數據的值,在小程序界面中無法獲取到對應的值。
后續才發現,原來如果你希望由 WePY 替你更新和管理數據,你需要將要傳遞到頁面的數據放在頁面實例中的 data
對象中,這樣 WePY 才會幫你更新和管理數據。由于在文檔中并沒有注明這一點,所以我踩在了坑里。
后續對 WePY 進行分析后,理解了這樣的做法,由于 WePY 中沒有使用 setData
,而是直接調用 this.xxx
來進行修改,那么 WePY 就需要知道哪些變量應該發送到頁面,否則,將所有 this
中的數據都傳遞到頁面中,將會導致傳遞的時間過長,容易讓小程序退出,這時,使用 data
來限定數據的方法就可以理解了。
截止到目前,云開發并沒有提供除了微信小程序官方控制臺以外的管理方式,這就使得我們在構建應用的時候備受掣肘。
為了更好的提供服務,我們決定修改產品的模式。一開始我們考慮用戶提交翻譯,團隊進行審核的模式,但是考慮到沒有管理端和開發成本的問題。我們決定調整一下模式,改為社區自凈化。我們完全開放編輯的能力,任何用戶都可以提交數據。同時,也可以在國內實踐一個完全由社區維護的應用。
但是,這種任何人都可以提交數據很有可能被人所利用,所以,我們引入了微信小程序官方提供的內容安全接口,來進行文本的安全檢測,從而,盡可能的規避一些違法違規內容對小程序的影響。
如果你用這個接口,你就會知道,接口的調用時需要使用 access_token
,而微信的 access_token
獲取接口既有發起調用的地址限制(不能在小程序中調用),也有接口請求頻率的限制(請求過快可能會導致無法獲取到 Token),因此,我們決定使用云函數來處理這部分的功能。
我們在云函數內使用 got
這個庫來請求微信提供的接口,進行 access_token
的獲取,以及內容安全的檢測。并且,為了確保 access_token
的請求不會頻率過快,所以我們加入了一些代碼,來進行 token 的緩存。
const result = await cache.get(); // cache 為對應 collection 的引用const now = (new Date).valueOf();const nextTime = now + 5400000;let accessToken = ''if (!result.data.length) { console.log("進入初次獲取的流程") const result = await got(accessTokenUrl) accessToken = JSON.parse(result.body).access_token await cache.add({ data: { token: accessToken, time: nextTime } })} else { if (result.data[0].time > now) { console.log("已有 token 有效") accessToken = result.data[0].token } else { console.log("已有 token 無效") const tokenResult = await got(accessTokenUrl) accessToken = JSON.parse(tokenResult.body).access_token await cache.doc(result.data[0]._id).update({ data:{ token: accessToken, time: nextTime } }) }}
通過上述代碼,實現了在云數據庫中存儲一個 token ,并比對其過期時間,如果發現 token 即將過期,就更新 token ,確保可以正常請求。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何實現Linux命令查詢小程序”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。