国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

基于Jquery與WebMethod投票功能實現代碼

2019-11-20 23:58:16
字體:
來源:轉載
供稿:網友
1:功能描述
1)最好是若干個星星組成,用戶投票時候只要鼠標點擊星星就可以實現投票,可以自定義星星個數
2)未投票、投票中、完成投票,星星的樣式不同
3)每個星星的都可以自定義提示 比如 “差” “一般” “還好” “不錯”
4)完成投票后,動畫展示投票結果并且不可再投票

2:思路描述
1、3)使用循環,最大值是星星的個數,每次循環添加一條<a></a>的語句,這條超鏈接通過Class指定星星樣式,通過title指定鼠標移到時顯示的文字,循環結束后通過Jquery的append函數添加到目標內容區
2)通過Jquery的addClass、removeClass 方法可以動態地調整星星的樣式,值得注意的是在打分的時候,鼠標移動到某個位置的星星,之前的星星都要添加上樣式,可以使用Jquery的prevAll()獲得當前位置之前的星星的引用 然后add($(this))來獲得當前位置星星的引用.
打分之前:
UnScore 
打分之中:
Scoreing
打分之后:
beenScore
4)根據目標區子節點里面被選擇星星的位置+1來產生分數 children().index($(this)) 然后該分數通過ajax與服務器交互,返回評價分,接著清空目標區內容,添加<span></span>背景圖片設置成星星圖片,在水平位置重復,就可以根據星星的寬度*平均分決定該<span></span>的最終寬度,并使用animate實現動畫效果.

3:實現代碼
1)javaScript代碼
為了方便,我把它做成了半插件形式, AJAX交互還是寫了自己的邏輯進去,代碼如下
復制代碼 代碼如下:

(function ($) {
$.fn.Rate = function (options) {
options = options || {};
var StarTip = options.StarTip || ['不值一看', '平平無奇', '信息靠譜', '對我很有幫助', '極品信息'];
var ItemAmount = options.ItemAmount || 5;
var UnRateClassName = options.UnRateClassName || 'star';
var RateClassName = options.RateClassName || 'star_on';
var originalStateClassName = options.originalStateClassName || 'OriginalState';
var PostURL = options.PostURL || '';
var DoAfterPost = options.DoAfterPost || function () { };
var userID = options.userID || '';
var messageID = options.messageID || '';
var content = $(this);
var starList = '';
for (var i = 0; i < ItemAmount; i++) {
starList += ['<a href="#" class="', UnRateClassName, '" title="', StarTip[i], '"></a>'].join('');
}
content.empty().append(starList).find('a').hover(function () {
$(this).prevAll().add($(this)).addClass(RateClassName);
}, function () {
$(this).prevAll().add($(this)).removeClass(RateClassName);
}).one('click', function () {
var score = parseInt(content.children().index($(this))) + 1;
$.ajax({
type: "POST",
url: PostURL,
data: "{messageID:" + messageID + ",userID:" + userID + ",Score:" + score + "}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (msg) {
var result = (jQuery.parseJSON(msg.d)).SuccessFlag;
DoAfterPost(result);
content.empty().removeClass();
$('<span></span>').addClass(originalStateClassName).prependTo(content).animate({ 'width': 16 * result + 'px', 'opacity': 1 }, 'slow');
}
});
});

};

})(jQuery);

參數說明:

參數名稱描述默認值參數類型
StarTip鼠標移到星星上的文本提示['不值一看', '平平無奇', '信息靠譜', '對我很有幫助', '極品信息']javascript數組
[tip]:數組元素個數必須要和星星個數一致
ItemAmount星星的個數5數字
UnRateClassName還沒投票時星星的樣式名稱'star'字符串
RateClassName投票中,鼠標移過時星星的樣式'star_on'字符串
originalStateClassName 投票完成后,結果展示時星星的樣式'OriginalState'字符串
PostURLajax交互時,url參數''字符串
DoAfterPost投票完成后,在投票頁面使用自定義方法''字符串
userIDajax交互時用戶ID,防止重復投票''數字
messageIDajax交互時文章ID''數字
2)前端引用代碼
復制代碼 代碼如下:

$('#left table tr:eq(1) td:eq(0) #StarRate').Rate({
PostURL: 'http://www.cnblogs.com/ServiceProvider/MessageInfoService.asmx/VoteMessage',
userID: UserID,
messageID: messageID,
DoAfterPost: function (data) {
if (data > 0) {
$(voteResultContext).html(data);
}
else {
ProcessNoticeShow('您已經投過票了');
}
}
});
}

4)樣式表
復制代碼 代碼如下:

.star{ height:16px; width:16px;float:left; background:url(../images/star.gif) no-repeat 0 0;}
.star_on{ background: url(../images/star.gif) no-repeat 0 -32px !important;}
.OriginalState{ width:0px;background: url(../images/star.gif) repeat-x 0 -16px !important;opacity:0;height:16px; display:block;}

3)服務器端代碼
復制代碼 代碼如下:

/// <summary>
/// 對信息進行投票,返回值大于0代表成功
/// </summary>
/// <param name="messageID">信息ID</param>
/// <param name="userID">用戶ID</param>
/// <param name="Score">得分</param>
/// <returns></returns>
[WebMethod]
public string VoteMessage(int messageID, int userID ,int Score)
{
SQLCMD = new SqlCommand("MessageInfo_Add_VoteUsefull_MessageIDUserID", SQLConnect);
SQLCMD.CommandType = CommandType.StoredProcedure;
SQLCMD.Parameters.Add(new SqlParameter("@messageID",SqlDbType.Int));
SQLCMD.Parameters["@messageID"].Value = messageID;
SQLCMD.Parameters.Add(new SqlParameter("@userID",SqlDbType.Int));
SQLCMD.Parameters["@userID"].Value = userID;
SQLCMD.Parameters.Add(new SqlParameter("@Score", SqlDbType.Int));
SQLCMD.Parameters["@Score"].Value = Score;
float SuccessFlag = basicSQLAccess.ExeScalarReturnValueFloat(SQLCMD);
Hashtable HTFlag = new Hashtable();
HTFlag.Add("SuccessFlag", SuccessFlag);
return JsonConvert.SerializeObject(HTFlag);
}

有關JsonConvert.SerializeObject的內容介紹以及與前端Jquery交互 請看我之前的文章 <通過Jquery遍歷Json的兩種數據結構>
4:下載
壓縮包包括 css、JS、還有星星圖片
猛擊我下載
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 赤水市| 勐海县| 万山特区| 渑池县| 色达县| 澜沧| 田东县| 保山市| 会东县| 琼结县| 监利县| 多伦县| 岳池县| 禹城市| 秦安县| 金昌市| 泗阳县| 娱乐| 西平县| 崇文区| 磐安县| 罗定市| 突泉县| 盘山县| 连江县| 青岛市| 衡阳县| 夹江县| 晴隆县| 大厂| 阿克| 内丘县| 师宗县| 泗水县| 东阿县| 宜君县| 河津市| 寻甸| 柳林县| 廉江市| 宁夏|