靜態(tài)頁面實(shí)現(xiàn) include 引入公用代碼的示例
一直以來,我司的前端都是用 php 的 include 函數(shù)來實(shí)現(xiàn)引入 header 、footer 這些公用代碼的,就像下面這樣:
<!-- index.php --> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <?php include('header.php'); ?> <div>頁面主體部分</div> <?php include('footer.php'); ?> </body> </html>
<!-- header.php --> <header>這是頭部</header>
<!-- footer.php --> <footer>這是底部</footer>
直到最近某個(gè)項(xiàng)目需要做一個(gè) webapp,是通過 HBuilder 將靜態(tài)頁面打包成 APP,這就讓我碰到難題了。
如果是小項(xiàng)目,那就直接手動(dòng)多復(fù)制粘貼幾遍,但如果頁面較多,復(fù)制粘貼的方案明顯不靠譜,維護(hù)成本也高。
在查了很多資料后,最終確定用 gulp 來解決,具體操作如下:
1、安裝 gulp 和 gulp-file-include
首先新建個(gè)文件夾,在終端里定位到文件夾的位置,然后進(jìn)行 npm 初始化
npm init
然后安裝 gulp
npm install gulp --save-dev
接著安裝 gulp-file-include
npm install gulp-file-include --save-dev
2、新建并配置 gulpfile.js
接著我們手動(dòng)新建一個(gè) js 文件取名為 gulpfile,并在里面寫入如下代碼:
var gulp = require('gulp'); var fileinclude = require('gulp-file-include'); gulp.task('fileinclude', function () { // 適配page中所有文件夾下的所有html,排除page下的include文件夾中html gulp.src(['page/**/*.html', '!page/include/**.html']) .pipe(fileinclude({ prefix: '@@', basepath: '@file' })) .pipe(gulp.dest('dist')); });
3、創(chuàng)建項(xiàng)目目錄結(jié)構(gòu),并添加測試代碼
項(xiàng)目的整體目錄結(jié)構(gòu)應(yīng)該是這樣
app page include header.html footer.html index.html gulpfile.js package.json
然后我們添加測試代碼,header.html 和 footer.html 沒太多好說的,主要是 index.html 要特別注意引入的方式,代碼如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> @@include('include/header.html') <div>頁面主體部分</div> @@include('include/footer.html') </body> </html>
4、運(yùn)行
在終端里敲入以下代碼,看執(zhí)行效果
gulp fileinclude
會(huì)發(fā)現(xiàn),多了個(gè) dist 文件夾,里面有一個(gè) index.html 文件,gulp-file-include 已經(jīng)幫我們把最終編譯好的 index.html 文件生成好了。
可能你已經(jīng)能舉一反三了,在 gulpfile.js 里,我們可以手動(dòng)設(shè)置最終生成文件的位置,就是這句話
gulp.dest('dist')
5、自動(dòng)編譯
靜態(tài)頁面引入公用代碼的問題已經(jīng)解決了,但每次編寫源 html 后,都要去終端里手動(dòng)執(zhí)行下編譯操作還是很麻煩,那能不能讓文件自動(dòng)編譯呢?答案一定是可以的。
gulp 有個(gè) watch 方法,就是監(jiān)聽文件是否有變動(dòng)的,我們只需稍微修改下 gulpfile.js 文件,增加一段監(jiān)聽代碼,如下:
var gulp = require('gulp'); var fileinclude = require('gulp-file-include'); gulp.task('fileinclude', function () { // 適配page中所有文件夾下的所有html,排除page下的include文件夾中html gulp.src(['page/**/*.html', '!page/include/**.html']) .pipe(fileinclude({ prefix: '@@', basepath: '@file' })) .pipe(gulp.dest('dist')); }); gulp.task('watch', function () { gulp.watch('page/**/*.html', ['fileinclude']); });
寫好之后,我們只需在終端里執(zhí)行
gulp watch
我們每次保存源 html 后,gulp 就會(huì)自動(dòng)幫我們編譯一遍。
至此,靜態(tài)頁面如何實(shí)現(xiàn) include 引入公用代碼的問題,順利解決,最后附上相關(guān)資料。
以上這篇靜態(tài)頁面實(shí)現(xiàn) include 引入公用代碼的示例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JS代碼隨機(jī)生成姓名、手機(jī)號(hào)、身份證號(hào)、銀行卡號(hào)
下面小編自己寫的一個(gè)js生成器代碼,代碼比較簡單,實(shí)用性非常高,感興趣的朋友一起學(xué)習(xí)吧2016-04-04Postman如何實(shí)現(xiàn)參數(shù)化執(zhí)行及斷言處理
這篇文章主要介紹了Postman如何實(shí)現(xiàn)參數(shù)化執(zhí)行及斷言處理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07JS+HTML實(shí)現(xiàn)經(jīng)典游戲吃豆人
吃豆游戲可以說是我們80,90后共同的回憶錄,小時(shí)候常常在學(xué)習(xí)機(jī)上玩,所以也就有了強(qiáng)烈的欲望去寫。所以本文將利用JS+HTML實(shí)現(xiàn)這一經(jīng)典游戲,需要的可以參考一下2022-04-04jQuery ajax(復(fù)習(xí))—Baidu ajax request分離版
你沒有看錯(cuò)標(biāo)題,本文的確是在講Baidu ajax,不過是很久很久以前的版本了,我們先分析一段簡單的ajax代碼,來自早期的百度七巧板項(xiàng)目通過這個(gè)來先復(fù)習(xí)一遍ajax的知識(shí)2013-01-01JavaScript中的淺拷貝和深拷貝原理與實(shí)現(xiàn)淺析
這篇文章主要介紹了JavaScript中的淺拷貝和深拷貝原理與實(shí)現(xiàn),JavaScript 中的淺拷貝和深拷貝指的是在復(fù)制對象(包括對象、數(shù)組等)時(shí),是否只復(fù)制對象的引用地址或者在復(fù)制時(shí)創(chuàng)建一個(gè)新的對象2023-04-04基于javascript實(shí)現(xiàn)圖片滑動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了基于javascript實(shí)現(xiàn)圖片滑動(dòng)效果的相關(guān)資料,具有一定的參考價(jià)值,感興趣的朋友可以參考一下2016-05-05JavaScript實(shí)現(xiàn)連連看連線算法
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)連連看連線算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01