WordPress中利用AJAX異步獲取評論用戶頭像的方法
在評論者輸入郵箱后,異步獲得評論者的頭像并顯示出來,個人感覺這個功能雖不能給用戶體驗帶來多大的提升,也不算是一個實用的功能,但至少很炫,看到有的網(wǎng)站有添加這個功能,我也不甘寂寞所以也寫了個腳本,沒有時間做封裝,所以直接上原理和代碼。
異步動態(tài)調(diào)用頭像原理
- 獲得用戶輸入
- 過濾用戶輸入
- 傳遞變量到后臺
- 后臺處理數(shù)據(jù),并返回頭像的HTML代碼
- 獲得后臺返回數(shù)據(jù),將HTML代碼加載到當前頁面
貌似很多步驟,其實很簡單,我們只要將自己的主題稍作修改就可以到達效果。
簡單功能截圖:

實現(xiàn)
功能代碼:JavaScript
以下代碼需集成 JQuery 框架中。
apiurl 變量為你的php api 接口文件地址,文件代碼下面有。
功能主要集中在email輸入框失去焦點的動作上。
function getAvatar(authorEmail) {//獲得頭像代碼封裝函數(shù)
var nowtime = Math.round(new Date().getTime() / 1000);
$.get(apiurl, {
action : "get_avatar",
email : authorEmail,
t : nowtime
}, function(data) {
$('#get-avatar-img').fadeOut('slow', function() {
$('#get-avatar-img').html(data).fadeIn();
})
});
}
var avatarhtml = '<div id="get-avatar-img" style="display:none;">';
avatarhtml += '</div>';
$('#respond').append(avatarhtml);//添加頭像HTML
if($('#email').val().length > 1)
getAvatar($('#email').val());//獲得郵箱地址
$('#email').focusout(function() {//email輸入框失去焦點綁定的動作
var authorEmail = $('#email').val();
var pattern = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;
var flag = pattern.test(authorEmail);
if(flag) {
$('#get-avatar-img').html('載入頭像中').fadeIn('fast');
getAvatar(authorEmail);
} else {
alert('請輸入正確郵箱地址');
}
})
后臺響應代碼,在這里我用了一個單獨的頁面文件來做響應,
這樣做的好處是不用打開每個頁面的時候都去調(diào)用這部分代碼,
只是在做出請求時才去響應,這樣做可以完全摒棄主題的向后兼容顧慮。
當然你也可以將響應函數(shù)掛載到wp的hook上。
$action = isset($_REQUEST['action']) ? $_REQUEST['action'] : false ;
if($action){//留下以后添加功能的空間,你懂的。
switch ($action) {
case 'get_avatar':
$email = isset($_REQUEST['email']) ? $_REQUEST['email']: false ;
if($email){
echo get_avatar($email,60);
}
break;
default:
echo "請求內(nèi)容不充分";
break;
}
}
總結(jié)
So……. 很簡單吧?
請求-> 響應 -> 添加 總共三步曲。
當然,這里為了增強邏輯性,突出條理,把一些必要的數(shù)據(jù)過濾,
還有一些錯誤判斷,這些就算是留作思考吧。
- Ajax通過XML異步提交的方法實現(xiàn)從數(shù)據(jù)庫獲取省份和城市信息實現(xiàn)二級聯(lián)動(xml方法)
- ajax 異步獲取數(shù)據(jù)實現(xiàn)代碼 (js創(chuàng)建ajax對象)
- jQuery Ajax異步處理Json數(shù)據(jù)詳解
- jquery的ajax異步請求接收返回json數(shù)據(jù)實例
- jquery ajax屬性async(同步異步)示例
- Ajax請求中的異步與同步,需要注意的地方說明
- jquery的ajaxSubmit()異步上傳圖片并保存表單數(shù)據(jù)演示代碼
- 詳談 Jquery Ajax異步處理Json數(shù)據(jù).
- ajax異步刷新實現(xiàn)更新數(shù)據(jù)庫
- Ajax異步獲取html數(shù)據(jù)中包含js方法無效的解決方法
相關(guān)文章
JavaScript時間戳與時間日期間相互轉(zhuǎn)換
今天做項目遇到這樣的問題,要將獲取到的時間轉(zhuǎn)換為時間戳,通過查閱相關(guān)資料,問題順利解決,下面小編把具體實現(xiàn)代碼分享到腳本之家平臺,需要的朋友參考下2017-12-12
微信小程序?qū)崿F(xiàn)側(cè)邊欄二級聯(lián)動
這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)側(cè)邊欄二級聯(lián)動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07
微信小程序?qū)崿F(xiàn)倒計時調(diào)用相機自動拍照功能
這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)倒計時調(diào)用相機自動拍照功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06
js實現(xiàn)的點擊數(shù)量加一可操作數(shù)據(jù)庫
這篇文章主要介紹了js如何實現(xiàn)的點擊數(shù)量加一操作數(shù)據(jù)庫,需要的朋友可以參考下2014-05-05
JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之棧詳解
這篇文章主要介紹了JavaScript數(shù)據(jù)結(jié)構(gòu)與算法之棧詳解,本文講解了對棧的操作、對棧的實現(xiàn)實例等內(nèi)容,需要的朋友可以參考下2015-03-03

