靜態(tài)頁面實現(xiàn) include 引入公用代碼的示例
一直以來,我司的前端都是用 php 的 include 函數(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>
直到最近某個項目需要做一個 webapp,是通過 HBuilder 將靜態(tài)頁面打包成 APP,這就讓我碰到難題了。
如果是小項目,那就直接手動多復(fù)制粘貼幾遍,但如果頁面較多,復(fù)制粘貼的方案明顯不靠譜,維護(hù)成本也高。
在查了很多資料后,最終確定用 gulp 來解決,具體操作如下:
1、安裝 gulp 和 gulp-file-include
首先新建個文件夾,在終端里定位到文件夾的位置,然后進(jìn)行 npm 初始化
npm init
然后安裝 gulp
npm install gulp --save-dev
接著安裝 gulp-file-include
npm install gulp-file-include --save-dev
2、新建并配置 gulpfile.js
接著我們手動新建一個 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)建項目目錄結(jié)構(gòu),并添加測試代碼
項目的整體目錄結(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、運行
在終端里敲入以下代碼,看執(zhí)行效果
gulp fileinclude
會發(fā)現(xiàn),多了個 dist 文件夾,里面有一個 index.html 文件,gulp-file-include 已經(jīng)幫我們把最終編譯好的 index.html 文件生成好了。
可能你已經(jīng)能舉一反三了,在 gulpfile.js 里,我們可以手動設(shè)置最終生成文件的位置,就是這句話
gulp.dest('dist')
5、自動編譯
靜態(tài)頁面引入公用代碼的問題已經(jīng)解決了,但每次編寫源 html 后,都要去終端里手動執(zhí)行下編譯操作還是很麻煩,那能不能讓文件自動編譯呢?答案一定是可以的。
gulp 有個 watch 方法,就是監(jiān)聽文件是否有變動的,我們只需稍微修改下 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 就會自動幫我們編譯一遍。
至此,靜態(tài)頁面如何實現(xiàn) include 引入公用代碼的問題,順利解決,最后附上相關(guān)資料。
以上這篇靜態(tài)頁面實現(xiàn) include 引入公用代碼的示例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用phantomjs進(jìn)行網(wǎng)頁抓取的實現(xiàn)代碼
這篇文章主要介紹了使用phantomjs進(jìn)行網(wǎng)頁抓取的實現(xiàn)代碼,需要的朋友可以參考下2014-09-09
探討JavaScript標(biāo)簽位置的存放與功能有無關(guān)系
在網(wǎng)頁中,我們可以將JavaScript代碼放在html文件中任何位置,但一般放在head或body標(biāo)簽里面。一般來說,<script>元素放在哪里與其的功能作用是緊密相關(guān)的,通過本文我們一起學(xué)習(xí)下2016-01-01
js中setTimeout的妙用--防止循環(huán)超時
本文主要介紹了使用setTimeout實現(xiàn)防止循環(huán)超時的方法,具有很好的參考價值。下面跟著小編一起來看下吧2017-03-03
javascript中html字符串轉(zhuǎn)化為jquery dom對象的方法
最近項目需求要開發(fā)百度地圖相關(guān)的一個應(yīng)用,需要從硬編碼的html字符串中提取自己想要的元素以及屬性信息,由于在js中或者jq中操作元素節(jié)點以及屬性都是使用dom對象或者jq對象。下面介紹javascript中html字符串轉(zhuǎn)化為jquery dom對象的方法,需要的朋友可以參考下2015-08-08

