日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

javascript - 又是this指向問題

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

問題描述

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

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

<!DOCTYPE html><html><head> <meta charset='utf-8'> <title>星星評分插件</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> <!-- 建議放評分的盒子也放在同一個盒子里面并且與星星的標簽不一樣,這樣方面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://m.b3g6.com/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’, //鼠標移上去的樣式 starPoint: ’.star-point’ //星星評分};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; //經過的就添加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(){ //點擊后的星星個數以及分數 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){ //獲取評分 for(var k = 0; k<point; k++){this.className = active; }},getElem: function(obj){ //獲取dom元素 return document.querySelector(obj);},extend: function(source,value){ //拓展參數的函數 for(var i in value){if(value.hasOwnProperty(i)){ source[i] = value[i];} } return source;} }}())

問題解答

回答1:

感覺把 this 綁到 getStarPoint() 意義不大,因為除了當前元素,還有前面的元素都要置為 active,不如就 循環然后 star[k].className = active;

回答2:

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

回答3:

把str數組傳過去唄,getStarPoint 這個對純粹的循環操作 ,對this是啥并無要求。

回答4:

不太理解你說的 “star[i]和star[k]有相同的作用”, 是什么意思。如果onmouseover 知道自己是哪一個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; //經過的就添加active類} }})(i).....

}

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本强好片久久久久久aaa| 91久久久久| 老牛国内精品亚洲成av人片| 国产精品一站二站| 久久精品av| 欧美13videosex性极品| 国产aⅴ精品一区二区四区| 久久只有精品| 狠狠久久伊人| 都市激情国产精品| 亚洲先锋成人| 日韩午夜av在线| 亚洲免费专区| 亚洲精品婷婷| 不卡在线一区| 99精品视频在线| 久久中文欧美| 免费在线观看一区| 日韩三级视频| 国产黄色一区| 麻豆极品一区二区三区| 日韩精品一区二区三区中文| 日韩精品一区第一页| 99在线|亚洲一区二区| 99久久激情| 私拍精品福利视频在线一区| 四虎8848精品成人免费网站| 国产精品一区二区三区四区在线观看 | 日韩精品一区二区三区免费视频 | 欧美日韩视频| 欧美精品一区二区久久| 色在线中文字幕| 日本久久成人网| 91精品蜜臀一区二区三区在线| 美女视频黄久久| 国产欧美日韩视频在线| 国产精品亚洲人成在99www| 欧美一级网站| 亚洲最大av| 一区二区亚洲视频| 91精品丝袜国产高跟在线| 国产欧美在线| 免费亚洲一区| 91成人网在线观看| 欧美综合精品| 成人啊v在线| 亚洲在线网站| 国产精品大片免费观看| 日韩精品专区| 亚洲欧美久久| 欧美精品1区| 日韩视频一区| 欧美激情日韩| 亚洲一区免费| 国产麻豆精品久久| 91精品国产调教在线观看| 中文字幕视频精品一区二区三区| 蜜桃精品视频| 免费久久精品视频| 国产不卡av一区二区| 99国产精品视频免费观看一公开| 国产精品最新自拍| 亚洲激情黄色| 久久中文字幕一区二区| 亚洲欧美日本国产| 国产字幕视频一区二区| 麻豆成人综合网| 只有精品亚洲| 欧美日韩免费观看一区=区三区| 中文字幕日韩亚洲| 亚洲黄色在线| 99久久99视频只有精品| 久久国产视频网| 日韩一区精品字幕| 久久人人精品| 精品视频97| 国产免费播放一区二区| 爽好多水快深点欧美视频| 99久久久久国产精品| 成人影视亚洲图片在线| 国产亚洲字幕| 日韩一区精品字幕| 亚洲少妇自拍| 九一精品国产| 91亚洲一区| 亚洲啊v在线| 91看片一区| 久久不卡日韩美女| 日韩中文字幕av电影| 亚洲啊v在线免费视频| 日韩精品中文字幕一区二区| 日韩欧美中文字幕电影| 日韩和欧美一区二区三区| 亚洲精选久久| 国产精品观看| 日韩欧美一区二区三区在线观看| 四季av一区二区凹凸精品| 日韩精品欧美激情一区二区| 欧美日韩国产传媒| 亚洲视频综合| 日韩一区欧美二区| 欧美二区视频| 色综合视频一区二区三区日韩 | 日韩**一区毛片| 日韩精品免费一区二区三区| 日韩高清成人| 久久99伊人| 久久免费精品| 亚洲女同中文字幕| 国产欧美一区二区三区国产幕精品 | 国产成人免费| 久久久久久黄| 美国三级日本三级久久99| 综合视频一区| 久久99高清| 欧美日韩在线网站| 一区二区三区网站| 大香伊人久久精品一区二区| 日韩一区二区久久| 精品国产18久久久久久二百| 黄色av一区| 国产精品99在线观看| 在线国产一区二区| 久久精品人人| 男人的天堂久久精品| 高清一区二区三区av| 巨乳诱惑日韩免费av| 日韩精品免费视频人成| 亚洲综合电影| 国产私拍福利精品视频二区| 蜜桃视频在线网站| 日韩高清三区| 午夜精品免费| 伊人久久在线| 欧美精品福利| 蜜臀久久99精品久久久久久9| 欧美亚洲日本精品| 久久精品国产福利| 亚洲精品综合| 中文日韩欧美| 日韩和的一区二在线| 97久久亚洲| 蜜桃一区二区三区在线观看| 欧美日韩国产v| 精品黄色一级片| 国产剧情一区二区在线观看| www成人在线视频| 蜜臀91精品国产高清在线观看| 荡女精品导航| 久久免费影院| 国产精品亲子伦av一区二区三区| 国产精品白浆| 日韩黄色大片| 欧美专区在线| 久久精品99国产国产精| 久久精品亚洲一区二区| 欧美黄色网页| 日韩中文字幕亚洲一区二区va在线 | 日韩福利视频一区| 福利一区二区| 亚洲免费播放| 国产亚洲一卡2卡3卡4卡新区| 国产精品久久久久久久久久白浆 | 91精品观看| 成人羞羞视频播放网站| 亚洲精品福利| 激情综合自拍| 亚洲成人精品| 久久精品青草| 国产精品美女午夜爽爽| 亚洲午夜精品久久久久久app| 日韩中文影院| 亚洲91视频| 日本欧美一区二区在线观看| 欧美色图国产精品| 国产精品激情| 亚洲精品第一| 快she精品国产999| 日韩久久精品网| 国产欧美日韩综合一区在线播放| 免费久久99精品国产| 亚洲精品一区二区妖精| 99久久婷婷这里只有精品| 国产欧美日韩在线观看视频| 日韩一区欧美二区| 国产精品三上| 国产偷自视频区视频一区二区| 久久精品国产亚洲夜色av网站| 麻豆视频在线观看免费网站黄| 日韩精品高清不卡| 日本视频在线一区| 国产精品国码视频| 麻豆成人av在线| 蜜臀国产一区| 亚州av乱码久久精品蜜桃| 亚洲高清影视| 久久国产福利| 日韩av影院| 精品久久中文| 国产精品tv|