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

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

javascript - 又是this指向問題

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

問題描述

這是一個星星評分插件,用原生js寫的。將for(var k = 0)...這一段抽出來時,然后執(zhí)行到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://www.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; //經(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(){ //點擊后的星星個數(shù)以及分數(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){ //獲取評分 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() 意義不大,因為除了當前元素,還有前面的元素都要置為 active,不如就 循環(huán)然后 star[k].className = active;

回答2:

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

回答3:

把str數(shù)組傳過去唄,getStarPoint 這個對純粹的循環(huán)操作 ,對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; //經(jīng)過的就添加active類} }})(i).....

}

標簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久国产精品美女| 欧美日韩中文字幕一区二区三区| 日韩1区2区3区| 国产精品a级| 日韩国产在线| 国产精品三上| 欧美日韩一区二区国产| 成人国产精品久久| 91一区二区三区四区| 99精品国产一区二区三区| 免费久久99精品国产| 欧美aⅴ一区二区三区视频| 亚洲美女久久精品| 久久香蕉精品| 蜜桃精品视频| 亚洲精品一区二区妖精| 日韩精品一区二区三区免费视频| 老鸭窝一区二区久久精品| 亚洲v在线看| 日韩欧美2区| 国产理论在线| 视频在线在亚洲| 欧美激情福利| 啪啪国产精品| 91精品国产自产在线丝袜啪| 中文一区一区三区高中清不卡免费| 中文一区在线| 麻豆视频久久| 99在线|亚洲一区二区| 欧美私人啪啪vps| 1000部精品久久久久久久久| 91精品丝袜国产高跟在线| 999久久久免费精品国产| 欧美中文一区| 免费不卡中文字幕在线| 国产精品色在线网站| 欧美日韩国产免费观看视频| 免费一级欧美片在线观看网站| 国产成人精品福利| 国产真实久久| 新版的欧美在线视频| 国产精品毛片aⅴ一区二区三区| 爽好久久久欧美精品| 蜜臀91精品国产高清在线观看| 日韩a一区二区| 久久三级中文| 日韩综合在线| 精品欧美日韩精品| 国产精品久久久久久久久久齐齐| 亚洲精品激情| 亚洲一区二区小说| 在线综合欧美| 国产精品日韩| 亚洲激情精品| 美女亚洲一区| 婷婷激情综合| 欧美精品一卡| 亚洲精品1区| 蜜桃视频欧美| 在线精品视频在线观看高清| 久久美女精品| 欧美福利在线| 欧美另类专区| 欧美午夜不卡| 国产精品91一区二区三区| 99精品国产一区二区三区| 五月精品视频| 久久精品在线| 免费看久久久| 国产欧美日韩影院| 日韩专区视频网站| 日本不卡一区二区三区| 国产精品99在线观看| 亚洲伊人精品酒店| av中文字幕在线观看第一页| 亚洲人成高清| 欧美日韩1区2区3区| 国产精品老牛| 欧美综合另类| 99久久激情| 成人看片网站| 国产成人精品999在线观看| 久久av网站| 日韩精品欧美精品| 亚洲四虎影院| 国产成人精选| 国产欧美精品| 亚洲影视一区二区三区| 激情欧美国产欧美| 视频一区在线播放| 国际精品欧美精品| 精品视频网站| 久久97久久97精品免视看秋霞| 国产精品久久久亚洲一区| 国产伦理一区| 国产伦理久久久久久妇女| 国产丝袜一区| 2023国产精品久久久精品双| 国产精品亚洲四区在线观看| 国产一区二区三区四区五区传媒| 国产综合色区在线观看| 黄色日韩在线| 日本午夜精品久久久久| 国产精品99久久免费观看| 黄色在线网站噜噜噜| 欧美日韩国产综合网| 日韩三级视频| 精品国产网站| 午夜日韩在线| 国产另类在线| 日韩精品免费视频一区二区三区 | 青青草伊人久久| 久久精品97| 国产一区二区三区天码| 麻豆视频在线观看免费网站黄 | 婷婷亚洲综合| 影音先锋久久精品| 日本aⅴ精品一区二区三区 | 国产视频一区三区| 日韩欧美中文字幕电影| 欧美片第1页综合| 久久影院资源站| 人人精品亚洲| 中文精品电影| 免费日韩一区二区三区| 日韩在线短视频| 欧美亚洲在线日韩| 亚洲日本在线观看视频| 欧美日本三区| av资源中文在线天堂| 五月天激情综合网| 日本综合精品一区| 国产在线不卡一区二区三区| 99精品视频精品精品视频| 亚洲免费网址| 一区二区三区午夜视频| 国产乱码精品一区二区三区亚洲人| 国产一区二区三区四区五区| 欧美一区二区三区高清视频| 亚洲欧洲av| 成人台湾亚洲精品一区二区| 午夜电影亚洲| 国产精品综合| 激情丁香综合| 国产情侣一区| 久久久一二三| 天堂va在线高清一区| 日韩不卡一区| 在线免费观看亚洲| 六月丁香综合在线视频| 青青久久av| 亚洲午夜免费| 精品久久视频| 午夜在线视频一区二区区别| 国产毛片精品| 免费观看不卡av| 欧美天堂一区| 免费av一区二区三区四区| 国产日韩欧美三级| 久久国产影院| 欧美偷窥清纯综合图区| 日韩视频网站在线观看| 亚洲ww精品| 亚洲电影有码| 国产欧美日韩精品一区二区三区| 国产美女高潮在线| 亚洲一二三区视频| 三级精品视频| 欧美在线看片| 一本一本久久| 黄毛片在线观看| 国产探花在线精品一区二区| 91久久久精品国产| 粉嫩av一区二区三区四区五区 | 午夜久久黄色| 成人午夜毛片| 欧美片第1页综合| 亚洲免费播放| 四虎成人av| 日本成人在线一区| 国产高清一区| 成人亚洲精品| 国产亚洲观看| 日韩制服丝袜先锋影音| 伊人久久av| 久久99久久久精品欧美| 美美哒免费高清在线观看视频一区二区| 日韩.com| 国产精品久久久一区二区| 亚洲主播在线| 久久裸体视频| 日韩成人精品一区二区| 奇米777国产一区国产二区| 欧洲激情综合| 国产成人免费| 国产精品1区| 日本在线成人| 中文在线一区| 欧美日韩精品一区二区视频| 久久一区亚洲|