[發(fā)明專利]一種實(shí)現(xiàn)網(wǎng)站接口化渲染的方法與裝置有效
| 申請(qǐng)?zhí)枺?/td> | 201611131599.8 | 申請(qǐng)日: | 2016-12-09 |
| 公開(公告)號(hào): | CN106777055B | 公開(公告)日: | 2021-01-01 |
| 發(fā)明(設(shè)計(jì))人: | 杜偉 | 申請(qǐng)(專利權(quán))人: | 武漢斗魚網(wǎng)絡(luò)科技有限公司 |
| 主分類號(hào): | G06F16/958 | 分類號(hào): | G06F16/958 |
| 代理公司: | 湖北武漢永嘉專利代理有限公司 42102 | 代理人: | 許美紅 |
| 地址: | 430073 湖北省武漢市東湖開*** | 國省代碼: | 湖北;42 |
| 權(quán)利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關(guān)鍵詞: | 一種 實(shí)現(xiàn) 網(wǎng)站 接口 渲染 方法 裝置 | ||
本發(fā)明提供了一種實(shí)現(xiàn)網(wǎng)站接口化渲染的方法與裝置,該方法包括以下步驟:1)瀏覽器接收服務(wù)器響應(yīng)的HTML內(nèi)容,加載網(wǎng)站頁面首屏完畢后,由前端腳本獲取頁面中待接口化渲染的區(qū)塊;2)前端腳本找到了頁面中待接口化渲染的區(qū)塊后,將這些區(qū)塊緩存起來,同去本地配置文件中找到對(duì)應(yīng)的接口地址;3)根據(jù)緩存的區(qū)塊和區(qū)塊對(duì)應(yīng)的接口,前端腳本將會(huì)分批請(qǐng)求各個(gè)區(qū)塊所對(duì)應(yīng)的接口地址,從服務(wù)器上獲取各個(gè)區(qū)塊的HTML內(nèi)容;完成渲染;4)當(dāng)所有待接口化渲染的區(qū)塊完成渲染或被刪除處理后,結(jié)束。本發(fā)明方法使用接口進(jìn)行渲染,利于網(wǎng)站頁面的首屏渲染加速和降低網(wǎng)絡(luò)帶寬消耗,還能便于網(wǎng)站的SEO擴(kuò)展。
技術(shù)領(lǐng)域
本發(fā)明涉及互聯(lián)網(wǎng)技術(shù),尤其涉及一種實(shí)現(xiàn)網(wǎng)站接口化渲染的方法與裝置。
背景技術(shù)
目前互聯(lián)網(wǎng)彈幕直播網(wǎng)站的頁面渲染邏輯一般都是:客戶端瀏覽器發(fā)送請(qǐng)求給網(wǎng)站服務(wù)器,服務(wù)器收到請(qǐng)求并完成頁面內(nèi)容渲染,然后服務(wù)器響應(yīng)內(nèi)容給客戶端瀏覽器,瀏覽器再解析服務(wù)器響應(yīng)的內(nèi)容并渲染展示給用戶。當(dāng)頁面內(nèi)容越來越多,服務(wù)器上渲染頁面內(nèi)容的時(shí)間會(huì)增長,同時(shí)服務(wù)器與客戶端瀏覽器之間的數(shù)據(jù)傳輸時(shí)間會(huì)變長,不僅影響用戶體驗(yàn),而且極大的增加的網(wǎng)站的帶寬消耗。
發(fā)明內(nèi)容
本發(fā)明要解決的技術(shù)問題在于針對(duì)現(xiàn)有技術(shù)中的缺陷,提供一種實(shí)現(xiàn)網(wǎng)站接口化渲染的方法與裝置。
本發(fā)明解決其技術(shù)問題所采用的技術(shù)方案是:一種實(shí)現(xiàn)網(wǎng)站接口化渲染的方法,包括以下步驟:
1)瀏覽器接收服務(wù)器響應(yīng)的HTML內(nèi)容,加載網(wǎng)站頁面首屏完畢后(即window.onload事件),由前端腳本獲取頁面中待接口化渲染的區(qū)塊;
所述頁面中待接口化渲染的區(qū)塊是前端預(yù)先定義好的有data-async-render屬性的HTML DIV元素;
前端腳本通過尋找當(dāng)前網(wǎng)頁中所有包含data-async-render屬性的DIV元素,以此來收集當(dāng)前網(wǎng)頁中待接口渲染的容器;如果前端腳本沒有找到了待接口化渲染的區(qū)塊,則終止執(zhí)行,否則進(jìn)入步驟2)
2)前端腳本找到了頁面中待接口化渲染的區(qū)塊后,將這些區(qū)塊緩存起來,同時(shí)根據(jù)區(qū)塊的data-async-render屬性的值,去本地配置文件中找到對(duì)應(yīng)的接口地址,所述本地配置文件是前端提前定義好的js文件,在頁面初始化的時(shí)候會(huì)被頁面加載;
3)根據(jù)緩存的區(qū)塊和區(qū)塊對(duì)應(yīng)的接口,前端腳本將會(huì)分批請(qǐng)求各個(gè)區(qū)塊所對(duì)應(yīng)的接口地址,從服務(wù)器上獲取各個(gè)區(qū)塊的HTML內(nèi)容;
如果接口返回正確,前端腳本將從服務(wù)器上獲得的各個(gè)區(qū)塊的HTML內(nèi)容插入到對(duì)應(yīng)的各個(gè)區(qū)塊中去,瀏覽器會(huì)自動(dòng)完成渲染;
反之如果請(qǐng)求失敗,前端腳本將會(huì)從頁面中和緩存中刪除對(duì)應(yīng)的區(qū)塊;
4)當(dāng)所有待接口化渲染的區(qū)塊完成渲染或被刪除處理后,結(jié)束。
按上述方案,所述步驟1)DIV元素中data-async-render屬性,其屬性的值是唯一的,用于區(qū)分其它的區(qū)塊。
按上述方案,所述步驟3)中分批請(qǐng)求區(qū)塊所對(duì)應(yīng)的接口地址時(shí),每批請(qǐng)求一個(gè)區(qū)塊所對(duì)應(yīng)的接口地址。
一種實(shí)現(xiàn)網(wǎng)站接口化渲染的裝置,包括:
獲取模塊,用于獲取網(wǎng)頁頁面中待接口化渲染的區(qū)塊;具體如下:瀏覽器接收服務(wù)器響應(yīng)的HTML內(nèi)容,加載網(wǎng)站頁面首屏完畢后,由前端腳本獲取頁面中待接口化渲染的區(qū)塊;
所述頁面中待接口化渲染的區(qū)塊是前端預(yù)先定義好的有data-async-render屬性的HTML DIV元素;
前端腳本通過尋找當(dāng)前網(wǎng)頁中所有包含data-async-render屬性的DIV元素,以此來收集當(dāng)前網(wǎng)頁中待接口渲染的容器;
該專利技術(shù)資料僅供研究查看技術(shù)是否侵權(quán)等信息,商用須獲得專利權(quán)人授權(quán)。該專利全部權(quán)利屬于武漢斗魚網(wǎng)絡(luò)科技有限公司,未經(jīng)武漢斗魚網(wǎng)絡(luò)科技有限公司許可,擅自商用是侵權(quán)行為。如果您想購買此專利、獲得商業(yè)授權(quán)和技術(shù)合作,請(qǐng)聯(lián)系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/201611131599.8/2.html,轉(zhuǎn)載請(qǐng)聲明來源鉆瓜專利網(wǎng)。
- 上一篇:半連接合并方法和半連接合并裝置
- 下一篇:圖片推送方法、服務(wù)器及終端
- 互動(dòng)業(yè)務(wù)終端、實(shí)現(xiàn)系統(tǒng)及實(shí)現(xiàn)方法
- 街景地圖的實(shí)現(xiàn)方法和實(shí)現(xiàn)系統(tǒng)
- 游戲?qū)崿F(xiàn)系統(tǒng)和游戲?qū)崿F(xiàn)方法
- 圖像實(shí)現(xiàn)裝置及其圖像實(shí)現(xiàn)方法
- 增強(qiáng)現(xiàn)實(shí)的實(shí)現(xiàn)方法以及實(shí)現(xiàn)裝置
- 軟件架構(gòu)的實(shí)現(xiàn)方法和實(shí)現(xiàn)平臺(tái)
- 數(shù)值預(yù)報(bào)的實(shí)現(xiàn)方法及實(shí)現(xiàn)系統(tǒng)
- 空調(diào)及其冬眠控制模式實(shí)現(xiàn)方法和實(shí)現(xiàn)裝置以及實(shí)現(xiàn)系統(tǒng)
- 空調(diào)及其睡眠控制模式實(shí)現(xiàn)方法和實(shí)現(xiàn)裝置以及實(shí)現(xiàn)系統(tǒng)
- 輸入設(shè)備實(shí)現(xiàn)方法及其實(shí)現(xiàn)裝置
- 與HTTP網(wǎng)站關(guān)聯(lián)的WAP網(wǎng)站
- 基于網(wǎng)站指紋推送白名單的方法及系統(tǒng)
- 網(wǎng)站漏洞檢測方法和系統(tǒng)
- 一種網(wǎng)站建立方法、裝置及計(jì)算設(shè)備
- 一種網(wǎng)站識(shí)別方法及裝置
- 網(wǎng)站風(fēng)險(xiǎn)評(píng)估方法及裝置
- 網(wǎng)站版權(quán)時(shí)間的管理方法、裝置、存儲(chǔ)介質(zhì)及設(shè)備
- 一種網(wǎng)站開發(fā)系統(tǒng)及方法
- 一種基于網(wǎng)站地圖的指紋識(shí)別方法
- 網(wǎng)站應(yīng)用框架指紋識(shí)別的方法、設(shè)備、裝置及介質(zhì)





