通常一個網站的head,foot,rightBar(右側的條目)都是相同的,這部分內容可以通過引入的方式,否則一旦需要修改,就需要修改十個,二十個,乃至更多的頁面,是一項既繁瑣但又毫無意義的工作。借助于PHP或者JSP,使用include能夠輕松解決此問題,但是如果脫離后端語言,從前端的角度,能不能解決這個問題呢?
### 1、借助于iframe
首先,最容易想到的應該是使用iframe,雖然html5廢除了frame,但是依舊保留了iframe,我們仍可以繼續使用,iframe有一個frameboder屬性,設置屬性值為0或者為no,去除iframe的邊框。然后將scrolling設為no。這是完全可行的,不過記得要在服務器環境下運行。
~~~
var frame = document.getElementsByTageName("iframe")[0];
frame.contentWindow.document.XXX方法,
如frame.contentWindow.document.querySelector("#btn");//獲取iframe中Id為btn的節點.
~~~
因為此前沒有使用iframe來引入頭部的經驗,考慮到頭部通常除了跳轉之外,另一個作用應該是定位,在頁面較長時,通過點擊,準確定位到某處。頁面的跳轉,使用iframe引入并無影響,那么錨點呢?這個需要試一試才知道。?
在此,再補充一點關于錨點的知識:?
錨點可以跳轉到當前頁面的相應位置,還可以跳轉到其它頁面的相應位置。?
實現錨點有兩種方式,一種是a標簽+name屬性,還有一種是使用標簽的Id屬性。?
具體如下:?
a.使用a標簽+name屬性的方式
~~~
<a href = "#detail">詳情</a>
<a name = "detail"></a>
~~~
點擊”詳情”,跳轉到`<a name = "detail">`的位置.
b.使用標簽的id屬性
~~~
<a href = "#detail">詳情</a>
<div id = "detail"></div>
~~~
點擊”詳情”,跳轉到`<div id = "detail">`的位置.
使用a+name的方式經常會出現錨點失效的情況,因此推薦使用id來綁定錨點。?
言歸正傳,引入iframe之后,我們能否通過點擊iframe中的元素來定位的相應的位置呢,這里,我們使用iframe引入head.html,這也是我最初的目的。?
因此我們要實現的是:點擊iframe的a標簽,定位到主Html相應的位置,通過實現發現,單純通過html是無法實現的,但是借助于JS則可以做到。
~~~
<!doctype html>
<html lang="en">
<head>
<!--網站編碼格式,UTF-8 國際編碼,GBK或 gb2312 中文編碼-->
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<meta name="Keywords" content="關鍵詞一,關鍵詞二">
<meta name="Description" content="網站描述內容">
<meta name="Author" content="Yvette Lau">
<title>Document</title>
<!--css js 文件的引入-->
<style>
#leftFrame{display:block;}
</style>
</head>
<body>
<div><img src = "img/photo1.jpg" width="500px"/></div>
<iframe src="test1.html" height= "100px" name="leftFrame" scrolling="No" noresize="noresize" id="leftFrame"></iframe>
<div><img src = "img/photo2.jpg" width="500px"/></div>
<div><img src = "img/photo3.jpg" width="500px" /></div>
<p id = "buttom">detail</p>
</body>
</html>
<script>
window.onload = function(){
var iframe = document.querySelector("#leftFrame");
var bot = iframe.contentWindow.document.querySelector("#bot");
var top = iframe.contentWindow.document.querySelector("#top");
bot.onclick = function(){
document.body.scrollTop = document.body.offsetHeight;
};
top.onclick = function(){
document.body.scrollTop = 0;
};
};
</script>
~~~
iframe中有id為bot和top的元素。通過JS的方式實現定位。?
在主頁面中,通過iframe.contentWindow能夠以HTML對象來返回iframe中的文檔,可以通過所以標準的DOM方法來處理被返回的對象。?
在iframe頁面中,通過parent定位到父html,可以通過top定位到頂層的html.?
同級iframe之間調用,需要先定位到父html,再定位到iframe.?
補充點關于錨點的知識,其關鍵作用的就是連接地址后面加的#detail(detail僅是泛指).如果當前的url為localhost:8080/index.html.那么錨點之后,url應為localhost:8080/index.html#detail?
URL地址末尾帶有”#”標識符,表示需要跳轉到對應的位置。#idName,瀏覽器會在頁面中找到符合”#idName”特點的標簽。如果URL中”#”后面跟隨的字符在文中找不到,如果是當前頁面,那么不跳轉,如果是從其它頁面跳轉過來,則顯示頁面頂部。?
回到頁面頂部,除了可以通過JS設置body的scrollTop(0返回到頂部,設置為body的高度,跳轉到頂部),另一種方法就是`<a href = "#">回到頂部</a>`
### 2、借助于ajax(jquery的load方法)
另外還有一種方法,是借助于jQuery的load方法載入頁面。?
load(url, data, callback);url是待裝入HTML網頁網址;data:發送至服務器的key/value;callback:載入成功時回調函數。
~~~
$(function(){
$("selector1").load("page1.html");
$("selector2").load("page2.html");
$("selector3").load("page3.html");
});
~~~
通過js追加進來的DOM結構,對SEO(搜索引擎優化)有影響,類似百度蜘蛛是無法抓取的!一般情況下不到萬不得已的時候,不推薦使用。page1.html/page2.html/page3.html寫需要的Html片段即可,因為是load進來的,也就是異步加載,在需要獲取page1.html等頁面的元素時,可以結合setTimeout使用,確保頁面被加載進來。
### 3、使用HTML imports
HTML imports提供了一種在一個HTML文檔中包含和重用另一個HTML文檔的方法。目前谷歌已經全面支持HTML imports,Opera35版本之后支持,但是FF依舊不支持。(在谷歌的地址欄輸入:chrome://flags,啟動或禁止一些功能)?
盡管目前HTML imports的兼容不是很好,但是我們還是有必要了解其使用方法,W3C已經發布了HTML imports的標準草案,相信后期應該還是會用得比較普遍的。使用HTML imports?
~~~
<!doctype html>
<html lang="en">
<head>
<!--網站編碼格式,UTF-8 國際編碼,GBK或 gb2312 中文編碼-->
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<meta name="Keywords" content="關鍵詞一,關鍵詞二">
<meta name="Description" content="網站描述內容">
<meta name="Author" content="Yvette Lau">
<title>Document</title>
<link rel = "import" href = "test1.html"/>
</head>
<body>
<div id = "content"></div>
</body>
</html>
<script>
var post = document.querySelector("link[rel = 'import']").import;
var con = post.querySelector("div");
document.querySelector("#content").appendChild(con.cloneNode(true));
var clone = document.importNode(con,true)
document.querySelector("#content").appendChild(clone)
</script>
~~~
給出了兩種將import進來的html中我們需要的部分插入到當前html.
最后簡單介紹document.querySelector和document.querySelectorAll,這兩個方法是HTML5在Web API中新引入的方法,大大簡化了在原生Javascript代碼中選取元素。?
document.querySelector和document.querySelectorAll都是接收一個字符串作為參數,這個參數需要符合CSS選擇語法,即:標簽、類選擇器、ID選擇器,屬性選擇器(E[type=”XX”]),結構選擇器(:nth-child(n))等。不支持偽類選擇器。?
document.importNode(node,deep)方法把一個節點從另一個文檔復制到該文檔以便應用,第二個值為true,那么將該節點的所有子孫節點也復制過來。?
node.cloneNode(deep):對已有的節點進行克隆,deep值為true,表示克隆其子孫節點。如果deep為false,則只克隆該節點自身。
除了以上方法外,目前更為主流的一種方式是使用組件化開發。每一部分作為一個組件。
- 前言
- jQuery輪播圖插件
- JS模擬事件操作
- JS閉包與變量
- JS綁定事件
- HTML5之file控件
- JavaScript的this詞法
- JavaScript的this詞法(二)
- JS this詞法(三)
- JS檢測瀏覽器插件
- JS拖拽組件開發
- number輸入框
- Modernizr.js和yepnode.js
- DOM變化后事件綁定失效
- div和img之間的縫隙問題
- 詳解JavaScript作用域
- bootstrap入門
- 表單驗證(登錄/注冊)
- Bootstrap網格系統
- Bootstrap排版
- Bootstrap創建表單(一)
- Bootstrap表單(二)
- Bootstrap按鈕
- Bootstrap圖片
- Bootstrap字體圖標(glyphicons)
- Bootstrap的aria-label和aria-labelledby
- Bootstrap下拉菜單
- Bootstrap按鈕組
- Bootstrap按鈕菜單
- Bootstrap輸入框組
- Bootstrap導航元素
- Bootstrap導航欄
- sublimeText頻頻崩潰
- JQuery不同版本的差異(checkbox)
- Bootstrap面包屑導航、分頁、標簽、徽章
- Bootstrap警告
- Bootstrap進度條
- 前端的上傳下載
- JS字符串的相關方法
- CSS3選擇器(全)
- CSS3新增文本屬性詳述
- 利用CSS3實現圖片切換特效
- CSS3新增顏色屬性
- CSS3的border-radius屬性詳解
- JS創建對象幾種不同方法詳解
- JS實現繼承的幾種方式詳述(推薦)
- CSS3響應式布局
- JS模塊化開發(requireJS)
- 利用@font-face實現個性化字體
- 前端在html頁面之間傳遞參數的方法
- CSS自動換行、強制不換行、強制斷行、超出顯示省略號
- 如何在Html中引入外部頁面
- reactJS入門
- React組件生命周期
- 使用React實現類似快遞單號查詢效果
- ReactJS組件生命周期詳述
- React 屬性和狀態詳解