JavaScript實(shí)現(xiàn)99乘法表及隔行變色實(shí)例代碼
項(xiàng)目需求:實(shí)現(xiàn)在頁面中輸出99乘法表。(要求:以每三行為一組,實(shí)現(xiàn)隔行變色(顏色為白,紅,黃(也可自己定義)),鼠標(biāo)滑過每一行,行背景顏色變?yōu)樗{(lán)色,鼠標(biāo)離開又恢復(fù)原來的顏色),隔行變色的效果需要用if和switch兩種判斷方式都能實(shí)現(xiàn);
額,分析一下實(shí)例要求:一個(gè)99乘法表,一個(gè)多方法的隔行變色,鼠標(biāo)滑過變另外一個(gè)顏色,離開恢復(fù)原色。 嗯,我們一步步來吧!
99乘法表的實(shí)現(xiàn),我相信很多人都知道怎么實(shí)現(xiàn),無非是2個(gè)for循環(huán)得到的結(jié)果,這里我就不多做解釋,還不理解的同學(xué)可以仔細(xì)研究一下代碼,研究一下實(shí)現(xiàn)的原理,我在核心代碼那里寫一點(diǎn)小注釋,方便你理解:
/*乘法表的表達(dá)式是 i*j 如: * *
所以第一個(gè)數(shù)從-,分別乘以-,就得到了乘法表
*/
//這里定義是為了記錄id的
var cur = ;
//這里是第一位數(shù)
for(var i=;i<=;i++){
//這里是第二位數(shù)
for(var j=;j<=i;j++){
var sum = i*j;
//這里創(chuàng)建div
var Div = document.createElement("div");
Div.id = cur ;
Div.style.top = i* + 'px';
Div.style.left = j* + 'px';
cur++;
//這里賦值
Div.innerHTML = j+"*"+i+"="+sum;
document.body.appendChild(Div);
}
}
css樣式我就不寫了,分到的效果就是這樣的:

小學(xué)99乘法表,大家都很熟悉,那我們實(shí)現(xiàn)第二個(gè)功能,隔行變色,要求是用if和switch實(shí)現(xiàn),那我們先用for來實(shí)現(xiàn)(這里用的3種顏色是:綠,灰,橙):
var cur = 1;
var bg = null;
for(var i=0;i<=9;i++){
for(var j=0;j<=i;j++){
var sum = i*j;
var Div = document.createElement("div");
var num = "div" + cur;
Div.id = num ;
Div.style.top = i*35 + 'px';
Div.style.left = j*105 + 'px';
cur++;
Div.innerHTML = j+"*"+i+"="+sum;
document.body.appendChild(Div);
var oDiv = document.getElementById(num);
if(cur%3 == 0){
bg="green";
}else if(cur%3 == 1){
bg="grey";
}else if(cur%3 == 2){
bg="orange";
oDiv.style.backgroundColor= bg;
}
}
實(shí)現(xiàn)效果是這樣的:

用switch方法實(shí)現(xiàn):
var cur = 1;
var bg = null;
for(var i=0;i<=9;i++){
for(var j=0;j<=i;j++){
var sum = i*j;
var Div = document.createElement("div");
var num = "div" + cur;
Div.id = num ;
Div.style.top = i*35 + 'px';
Div.style.left = j*105 + 'px';
cur++;
Div.innerHTML = j+"*"+i+"="+sum;
document.body.appendChild(Div);
var oDiv = document.getElementById(num);
switch(cur%3){
case 0 :
bg="green";
break;
case 1 :
bg="grey";
break;
case 2 :
bg="orange";
break;
}
oDiv.style.backgroundColor= bg;
}
}
實(shí)現(xiàn)效果是這樣的:

效果好像無差,哈哈,說來實(shí)現(xiàn)方法也是挺簡單的,現(xiàn)在看看移入表色是怎么做的,以switch判斷為例:
var cur = ;
var bg = null;
for(var i=;i<=;i++){
for(var j=;j<=i;j++){
var sum = i*j;
var Div = document.createElement("div");
var num = "div" + cur;
Div.id = num ;
Div.style.top = i* + 'px';
Div.style.left = j* + 'px';
cur++;
Div.innerHTML = j+"*"+i+"="+sum;
document.body.appendChild(Div);
var oDiv = document.getElementById(num);
switch(cur%){
case :
bg="green";
break;
case :
bg="grey";
break;
case :
bg="orange";
break;
}
oDiv.style.backgroundColor= bg;
}
}
var oDiv = document.getElementsByTagName("div");
var len = oDiv.length;
for(var i=;i<len;i++){
//鼠標(biāo)移入
oDiv[i].onmouseover = function(){
//第一種寫法,可以獲取行內(nèi)樣式(用style包起來的),也可以獲取樣式表中的樣式,且值為計(jì)算過的
//var defaultBg = getStyle(this,'background-color');
//第二種寫法,只能獲取style包起來的行內(nèi)樣式,值沒有經(jīng)過計(jì)算
var defaultBg = this.style.backgroundColor; //這里是為了存元素剛移入時(shí)的背景顏色
this.style.backgroundColor = 'red';
this.onmouseout = function(){
this.style.backgroundColor = defaultBg;
}
}
}
//這里是獲取元素的樣式值,兼容性寫法
function getStyle(obj,attr){
if(obj.currentStyle){
return obj.currentStyle[attr];
}else{
return getComputedStyle(obj,false)[attr];
}
}
得到的效果我就不截圖了,自行腦補(bǔ),或者自己也寫一下,到此,所以的要求都寫完了!你以為真的到這里就完了嗎?按照我一貫的風(fēng)格,當(dāng)然沒有完,后面還有料!往下看:
你不覺得這個(gè)隔行變色有點(diǎn)奇怪嗎,確實(shí)是隔行變了色,如果是100*100的div,效果杠杠的,但是像99乘法表這樣的結(jié)果,我只能說呵呵,那能不能讓99乘法表實(shí)現(xiàn)像100*100的div那樣的隔行變色呢?咱們說工匠精神,就是要在乎這些細(xì)枝末節(jié),寫寫看唄!
原理:100*100的div,如果我給每一個(gè)編一個(gè)號(hào),用橫軸和縱軸表示,像這樣:

那我們就知道,什么數(shù)值對(duì)應(yīng)什么顏色了,轉(zhuǎn)化成99乘法表就是這樣:

那,思路就來了,如果我給每個(gè)div加一個(gè)標(biāo)記,表示他是第幾行的第幾列,我就知道他是什么顏色,那代碼就如下:
var cur = ;
var bg = null;
for(var i=;i<=;i++){
for(var j=;j<=i;j++){
var sum = i*j;
var Div = document.createElement("div");
var num = "div" + cur;
Div.id = num ;
Div.style.top = i* + 'px';
Div.style.left = j* + 'px';
Div.setAttribute('abc',i+''+j);//核心代碼就是這里啦,給每一個(gè)div 自定義一個(gè)屬性abc,將坐標(biāo)賦值給它
cur++;
Div.innerHTML = j+"*"+i+"="+sum;
document.body.appendChild(Div);
}
}
var oDiv = document.getElementsByTagName("div");
for(var i=;i<oDiv.length;i++){
var val = oDiv[i].getAttribute('abc');//這里獲取自定義屬性的值
//用這個(gè)值來判斷什么位置應(yīng)該是什么顏色
switch(val%){
case :
bg="green";
break;
case :
bg="grey";
break;
case :
bg="orange";
break;
}
oDiv[i].style.backgroundColor= bg;
}
得到的效果就是這樣的:

效果是不是棒棒噠,比上面的感覺還是舒服許多,所以,記住自定義屬性的強(qiáng)大功能,它能做很多棒棒噠事情,有時(shí)間,專門講講自定義屬性的牛X應(yīng)用,哈哈!
工匠精神,我們?cè)贁U(kuò)展一下,把上面的代碼稍微整理一下,做一個(gè)簡單的小封裝,就變成了一個(gè)求階乘的隔行變色的小應(yīng)用,感覺瞬間變得:就這樣 feel 倍爽!
function multiTable(m){
var cur = ;
var bg = null;
for(var i=;i<=m;i++){
for(var j=;j<=i;j++){
var sum = i*j;
var Div = document.createElement("div");
var num = "div" + cur;
Div.id = num ;
Div.style.top = i* + 'px';
Div.style.left = j* + 'px';
Div.setAttribute('abc',i+''+j);//核心代碼就是這里啦,給每一個(gè)div 自定義一個(gè)屬性abc,將坐標(biāo)賦值給它
cur++;
Div.innerHTML = j+"*"+i+"="+sum;
document.body.appendChild(Div);
}
}
var oDiv = document.getElementsByTagName("div");
for(var i=;i<oDiv.length;i++){
var val = oDiv[i].getAttribute('abc');//這里獲取自定義屬性的值
//用這個(gè)值來判斷什么位置應(yīng)該是什么顏色
switch(val%){
case :
bg="green";
break;
case :
bg="grey";
break;
case :
bg="orange";
break;
}
oDiv[i].style.backgroundColor= bg;
}
}
multiTable();
關(guān)于小編給大家介紹的JavaScript實(shí)現(xiàn)99乘法表及隔行變色實(shí)例代碼就給大家介紹這么多,希望對(duì)大家有所幫助!
相關(guān)文章
JavaScript性能陷阱小結(jié)(附實(shí)例說明)
JavaScript陷阱太多,因此我們得步步為營,下面這些點(diǎn),相信很多同學(xué)都會(huì)遇到,希望朋友們多注意下。JavaScript陷阱太多,因此我們得步步為營,下面是一些常見的影響性能的陷阱。2010-12-12
javascript中的prototype屬性實(shí)例分析說明
一說到prototype很多人可能第一個(gè)想到的是著名的prototype.js框架,當(dāng)然我們今天說的不是它,而是Javascript中的prototype屬性,一般都被翻譯為“原型”。這是一個(gè)比較特殊的屬性,Javascript中的繼承一般都依賴這屬性實(shí)現(xiàn)。2010-08-08
干貨分享:讓你分分鐘學(xué)會(huì)javascript閉包
干貨分享:讓你分分鐘學(xué)會(huì)javascript閉包,如何才能快速學(xué)會(huì)javascript閉包,本文為大家揭曉2015-12-12
JS異步文件分片斷點(diǎn)上傳的實(shí)現(xiàn)思路
在項(xiàng)目中有時(shí)會(huì)遇到大文件上傳,經(jīng)常會(huì)出現(xiàn)鏈接超時(shí)的問題,所以就需要使用文件分片上傳的方式來上傳大文件。下面通過本文給大家介紹js異步文件分片斷點(diǎn)上傳的實(shí)例代碼,需要的的朋友參考下吧2016-12-12
js禁止Backspace鍵使瀏覽器后退的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猨s禁止Backspace鍵使瀏覽器后退的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09
Bootstrap 過渡效果Transition 模態(tài)框(Modal)
這篇文章主要介紹了Bootstrap 過渡效果Transition 模態(tài)框(Modal),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03
JS實(shí)現(xiàn)新浪博客左側(cè)的Blog管理菜單效果代碼
這篇文章主要介紹了JS實(shí)現(xiàn)新浪博客左側(cè)的Blog管理菜單效果代碼,可實(shí)現(xiàn)基于鼠標(biāo)點(diǎn)擊事件動(dòng)態(tài)操作頁面元素樣式的功能,界面美觀大方,簡潔實(shí)用,需要的朋友可以參考下2015-10-10

