国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript - 又是this指向問題

瀏覽:124日期:2023-04-21 11:28:45

問題描述

這是一個(gè)星星評(píng)分插件,用原生js寫的。將for(var k = 0)...這一段抽出來時(shí),然后執(zhí)行到that.getStarPoint.call(this,point,active)這部分就不行了,這個(gè)this是指向star[i],如何將star[i]和star[k]有相同的作用呢?

html: (星星暫時(shí)用顏色塊代替)

<!DOCTYPE html><html><head> <meta charset='utf-8'> <title>星星評(píng)分插件</title> <meta name='renderer' content='ie-webkit'> <style>.star{ margin-top: 10px;}.star span, .star em{ display: inline-block; vertical-align: top;}.star span{ cursor: pointer; width: 16px; height: 16px; background: #eee;}.star span.active{ background: #333;} </style></head><body> <!-- 建議放評(píng)分的盒子也放在同一個(gè)盒子里面并且與星星的標(biāo)簽不一樣,這樣方面dom查找 --> <!-- 星星可以是圖片,也可以放在css里面 --> <p class='star'><span></span><span></span><span></span><span></span><span></span><em class='star-point'></em> </p></body> <script type='text/javascript' src='http://www.cgvv.com.cn/wenda/common.js'></script> <script type='text/javascript'>new Star(’.star’); </script></html>

js:

;(function(global,undefined){ ’use strict’ var _global; function Star(options){this.defaultOptions = { starBox: ’.star’, //裝星星的obj starActive: ’active’, //鼠標(biāo)移上去的樣式 starPoint: ’.star-point’ //星星評(píng)分};this.opt = this.extend(this.defaultOptions, options || {} || ’’);this.star = this.getElem(this.opt.starBox).getElementsByTagName(’span’);this.len = this.star.length;this.init(options); } Star.prototype = {constructor: this,init: function(options){ var that = this; var starBox = that.getElem(that.opt.starBox),starPoint = that.getElem(that.opt.starPoint),active = that.opt.starActive,star = starBox.getElementsByTagName(’span’),point = 0; for(var i = 0; i<this.len; i++){star[i].index = i;star[i].onmouseover = function(){ that.clearAllStar.call(this); /*for(var k = 0; k<this.len; k++){star[k].className = ’’; }*/ for(var j = 0; j<this.index + 1; j++){star[j].className = active; //經(jīng)過的就添加active類 }}star[i].onmouseout = function(){ for(var j = 0; j<this.index + 1; j++){star[j].className = ’’; //離開的就去掉active類 } //公用部分 /*for(var k = 0; k<point; k++){star[k].className = active; }*/ that.getStarPoint.call(this,point,active);}star[i].onclick = function(){ //點(diǎn)擊后的星星個(gè)數(shù)以及分?jǐn)?shù) point = this.index + 1; starPoint.innerHTML = point + ’分’; //公用部分 /*for(var k = 0; k<point; k++){star[k].className = active; }*/that.getStarPoint.call(this,point,active);} }},clearAllStar: function(){ //清理所有hover過的星星 for(var k = 0; k<this.len; k++){this.className = ’’; }},getStarPoint: function(point,active){ //獲取評(píng)分 for(var k = 0; k<point; k++){this.className = active; }},getElem: function(obj){ //獲取dom元素 return document.querySelector(obj);},extend: function(source,value){ //拓展參數(shù)的函數(shù) for(var i in value){if(value.hasOwnProperty(i)){ source[i] = value[i];} } return source;} }}())

問題解答

回答1:

感覺把 this 綁到 getStarPoint() 意義不大,因?yàn)槌水?dāng)前元素,還有前面的元素都要置為 active,不如就 循環(huán)然后 star[k].className = active;

回答2:

我覺得,你應(yīng)該將that作為getStarPoint的上下文,寫作that.getStarPoint.call(that, point, active);,此處that才是Star實(shí)例。

回答3:

把str數(shù)組傳過去唄,getStarPoint 這個(gè)對(duì)純粹的循環(huán)操作 ,對(duì)this是啥并無要求。

回答4:

不太理解你說的 “star[i]和star[k]有相同的作用”, 是什么意思。如果onmouseover 知道自己是哪一個(gè)star,可以用閉包把i傳過去:

for(var i = 0; i<this.len; i++) {

star[i].index = i;star[i].onmouseover = (function(i) { return function(){that.clearAllStar.call(this);/*for(var k = 0; k<this.len; k++){ star[k].className = ’’;}*/for(var j = 0; j<this.index + 1; j++){ star[j].className = active; //經(jīng)過的就添加active類} }})(i).....

}

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 日本一级级特黄特色大片 | 欧美乱一级在线观看 | aaa免费毛片 | 亚洲国产精品久久久久久网站 | 亚洲精品在线网站 | 欧美精品成人一区二区在线观看 | 亚洲国产午夜看片 | 国产一级片在线 | 在线播放精品一区二区啪视频 | 在线国产区 | 欧美精品三级在线 | 国产成人精品曰本亚洲77美色 | 精品午夜一区二区三区在线观看 | 99er精品| 免费观看a毛片一区二区不卡 | 91精品啪在线看国产网站 | 精品视频 九九九 | 91久久国产精品视频 | 欧美xx在线观看 | 俄罗斯一级毛片免费播放 | 狠狠色噜狠狠狠狠色综合久 | 日本久久综合网 | 久久久综合网 | 午夜一级成人 | 国产91久久最新观看地址 | 免费看一毛一级毛片视频 | 91aaa免费免费国产在线观看 | 欧美综合在线视频 | 久久草在线免费 | 狠狠澡夜夜澡人人爽 | 免费大片黄手机在线观看 | 美女在线网站免费的 | 国产免费v片在线看 | 国产小视频在线高清播放 | 在线中文字幕播放 | 久草新免费| 宅女福利视频在线看免费网站 | 亚洲欧美视频在线播放 | 日本一区二区三区精品视频 | 男人天堂视频网 | 国产欧美日韩不卡一区二区三区 |