网友真实露脸自拍10p,成人国产精品秘?久久久按摩,国产精品久久久久久无码不卡,成人免费区一区二区三区

小程序模板網

微信小程序云開發js抓取網頁內容

發布時間:2021-05-31 11:39 所屬欄目:小程序開發教程

最近在研究微信小程序的云開發功能。云開發最大的好處就是不需要前端搭建服務器,可以使用云端能力,從零開始寫出來一個能上線的微信小程序,避免了買服務器的開銷,對于個人來嘗試練手微信小程序從前端到后臺的開發,還是一個不錯的選擇。可以做到一天就能上線一個微信小程序。

云開發的優點

云開發為開發者提供完整的云端支持,弱化后端和運維概念,無需搭建服務器,使用平臺提供的 API 進行核心業務開發,即可實現快速上線和迭代,同時這一能力,同開發者已經使用的云服務相互兼容,并不互斥。

云開發目前提供三大基礎能力支持:

云函數:在云端運行的代碼,微信私有協議天然鑒權,開發者只需編寫自身業務邏輯代碼數據庫:一個既可在小程序前端操作,也能在云函數中讀寫的 JSON 數據庫存儲:在小程序前端直接上傳/下載云端文件,在云開發控制臺可視化管理

好了,介紹了這么多關于云開發的知識,感性的同學可以去研究研究。官方文檔地址:https://developers.weixin.qq....

網頁內容抓取

小程序是關于答題的,所以題目的來源是一個問題。上網搜,一個題目一個題目粘貼是一種方法,但是這樣的重復工作,估計粘個10左右就想放棄了。所以想到了網頁抓取。正好把之前學的node撿起來。

必備工具:Cheerio。一個類似于服務器端JQuery的包。主要用它來分析和過濾抓取來的內容。node的fs模塊。這個是node自帶的模塊,用來讀寫文件的。此處用來將解析好的數據寫入json文件。Axios(非必須)。用來抓取網站的HTML網頁。因為我要的數據是從網頁上點擊一個button后獲取渲染的,所以直接訪問這個網址是抓取不到的。無奈只能將想要的內容復制出來,存成字符串,去解析這個字符串。

接下來就可以用npm init來初始化一個node項目,一路回車后,即可生成一個package.json文件。
然后npm install --save axios cheerio安裝cheerio和axios包。

關鍵的是用cheerio來實現一個類似jquery的功能。只需將抓取到的內容cheerio.load(quesitons)一下即可,之后就可以按照jquery的操作取dom,組裝你想要的數據了。

最后用fs.writeFile將數據保存到json文件中,大功告成。

具體代碼如下:

let axios = require(axios);

let cheerio = require(cheerio);

let fs = require(fs);

// 我的html結構大致如下,有很多條數據

const questions = `

    `;

 

const $ = cheerio.load(quesitons);

var arr = [];

for (var i = 0; i < 300; i++) {
   var obj = {};
   obj.quesitons = $(#q + i).find(.question).text();
   obj.A = $($(#q + i).find(.answer)[0]).text();
   obj.B = $($(#q + i).find(.answer)[1]).text();
   obj.C = $($(#q + i).find(.answer)[2]).text();
   obj.D = $($(#q + i).find(.answer)[3]).text();
   obj.index = i + 1;
   obj.answer =
     $($(#q + i).find(.answer)[0]).attr(value) == 1
       ? A
       : $($(#q + i).find(.answer)[1]).attr(value) == 1
         ? B
         : $($(#q + i).find(.answer)[2]).attr(value) == 1
           ? C
           : D;
   arr.push(obj);
}

fs.writeFile(poem.json, JSON.stringify(arr), err => {
   if (err) throw err;
   console.log(json文件已成功保存!);

});

保存到json后的文件格式如下,這樣就可以通過json文件上傳到云端服務器了。

/

 

注意事項

微信小程序云開發的數據庫,上傳json文件的數據格式需要注意一下,之前一直提示格式錯誤,后來才發現,JSON 數據不是數組,而是類似 JSON Lines,即各個記錄對象之間使用 n 分隔,而非逗號。所以還需要對node寫出來的json文件做一個小處理之后才能上傳成功。


易優小程序(企業版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://www.xiuhaier.com/wxmini/doc/course/25858.html 復制鏈接 如需定制請聯系易優客服咨詢:800182392 點擊咨詢
QQ在線咨詢
AI智能客服 ×