利用js讀取動態(tài)網(wǎng)站從服務(wù)器端返回的數(shù)據(jù)
更新時間:2014年02月10日 15:11:23 作者:
這篇文章主要介紹了利用js讀取動態(tài)網(wǎng)站從服務(wù)器端返回的數(shù)據(jù),需要的朋友可以參考下
在html中利用js讀取動態(tài)網(wǎng)站從服務(wù)器端返回的數(shù)據(jù)進行顯示
1、js.html 頁面
需要引入 執(zhí)行jquery的js文件
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<script src="jquery-1.8.2.min.js"></script>
<script>
$(function(){
//$("#loaddata").click(function(){
$(document).ready(function(){
//使用getJSON方法讀取json數(shù)據(jù),
//注意:info.json可以是不同類型文件,只要其中的數(shù)據(jù)為json類型即可
$.getJSON('info.json',function(data){
var html = '';
$.each(data,function(i,item){
html += '<tr><td>'+item['name']+'</td>'+
'<td>'+item['sex']+'</td>'+
'<td>'+item.address+'</td>'+
'<td>'+item['home']+'</td></tr>';
});
$('#title').after(html);
//after方法:在每個匹配的元素之后插入內(nèi)容。
});
});
});
//注:可以是item.address,也可以是item['address']
//firefox報 json文件中 “語法錯誤 [”,單能加載數(shù)據(jù)
//ie chrome 無法加載數(shù)據(jù)
</script>
</HEAD>
<input type="button" value="加載數(shù)據(jù)" id="loaddata" />
<BODY>
<table id="infotable" >
<tr id="title"><th>姓名</th><th>性別</th><th>地址</th><th>主頁</th></tr>
</table>
</BODY>
</HTML>
info.json文件
[
{
"name":"zhangsan",
"sex":"man",
"address":"hangzhou",
"home":"http://www.zhangsan.com"
},
{
"name":"lisi",
"sex":"wumen",
"address":"beijing",
"home":"http://www.lisi.coms"
}
]
應(yīng)用場景 :
定期從數(shù)據(jù)庫中讀取的特定記錄放到靜態(tài)頁面上去展示,為了減少對數(shù)據(jù)庫訪問的壓力,把特定記錄數(shù)取出來存放在json中,頁面訪問鏈接不用實時請求數(shù)據(jù)庫。
至此可以將json中的內(nèi)容加載到html靜態(tài)也中去。
顯示不了中文的確是編碼問題,默認保存的json肯定是個記事本,然后改后綴名為json的,記事本默認編碼是ANSI的 顯示中文自然有問題,
解決方法:打開.json文件 文件 - 另存為 看到下面編碼格式了吧 選擇UTF-8 就可以了。
這里還有個容易出錯的地方:
請求json文件報405錯誤,明明路徑對的 但是還是報錯。
解決方法:修改請求方式為get請求:
1、js.html 頁面
需要引入 執(zhí)行jquery的js文件
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<script src="jquery-1.8.2.min.js"></script>
<script>
$(function(){
//$("#loaddata").click(function(){
$(document).ready(function(){
//使用getJSON方法讀取json數(shù)據(jù),
//注意:info.json可以是不同類型文件,只要其中的數(shù)據(jù)為json類型即可
$.getJSON('info.json',function(data){
var html = '';
$.each(data,function(i,item){
html += '<tr><td>'+item['name']+'</td>'+
'<td>'+item['sex']+'</td>'+
'<td>'+item.address+'</td>'+
'<td>'+item['home']+'</td></tr>';
});
$('#title').after(html);
//after方法:在每個匹配的元素之后插入內(nèi)容。
});
});
});
//注:可以是item.address,也可以是item['address']
//firefox報 json文件中 “語法錯誤 [”,單能加載數(shù)據(jù)
//ie chrome 無法加載數(shù)據(jù)
</script>
</HEAD>
<input type="button" value="加載數(shù)據(jù)" id="loaddata" />
<BODY>
<table id="infotable" >
<tr id="title"><th>姓名</th><th>性別</th><th>地址</th><th>主頁</th></tr>
</table>
</BODY>
</HTML>
info.json文件
復(fù)制代碼 代碼如下:
[
{
"name":"zhangsan",
"sex":"man",
"address":"hangzhou",
"home":"http://www.zhangsan.com"
},
{
"name":"lisi",
"sex":"wumen",
"address":"beijing",
"home":"http://www.lisi.coms"
}
]
應(yīng)用場景 :
定期從數(shù)據(jù)庫中讀取的特定記錄放到靜態(tài)頁面上去展示,為了減少對數(shù)據(jù)庫訪問的壓力,把特定記錄數(shù)取出來存放在json中,頁面訪問鏈接不用實時請求數(shù)據(jù)庫。
至此可以將json中的內(nèi)容加載到html靜態(tài)也中去。
顯示不了中文的確是編碼問題,默認保存的json肯定是個記事本,然后改后綴名為json的,記事本默認編碼是ANSI的 顯示中文自然有問題,
解決方法:打開.json文件 文件 - 另存為 看到下面編碼格式了吧 選擇UTF-8 就可以了。
這里還有個容易出錯的地方:
請求json文件報405錯誤,明明路徑對的 但是還是報錯。
解決方法:修改請求方式為get請求:
相關(guān)文章
BootStrap實現(xiàn)響應(yīng)式布局導(dǎo)航欄折疊隱藏效果(在小屏幕、手機屏幕瀏覽時自動折疊隱藏)
這篇文章主要介紹了BootStrap實現(xiàn)導(dǎo)航欄的響應(yīng)式布局,當在小屏幕、手機屏幕瀏覽時自動折疊隱藏的效果,非常不錯,具有參考借鑒價值,對bootstrap 響應(yīng)式布局導(dǎo)航欄功能感興趣的朋友一起學(xué)習(xí)吧2016-11-11
JavaScript樹形數(shù)據(jù)結(jié)構(gòu)處理
這篇文章主要介紹了JavaScript樹形數(shù)據(jù)結(jié)構(gòu)處理,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-07-07
JavaScript實現(xiàn)經(jīng)緯度轉(zhuǎn)換常用方法總結(jié)
WGS84坐標系、GCJ02坐標系、BD09坐標系和Web 墨卡托投影坐標系是我們常見的四個坐標系。這篇文章為大家整理了這四個坐標系之間相互轉(zhuǎn)換的方法,需要的可以參考一下2023-02-02
js實現(xiàn)的日期操作類DateTime函數(shù)代碼
感覺js自帶的Date類型對象用起來不是很方便,照著C#的DateTime做了一個2010-03-03

