Heim > Web-Frontend > js-Tutorial > So verwenden Sie JavaScript und CSS, um die Textfarbe zwischen Zeilen zu ändern_Javascript-Fähigkeiten

So verwenden Sie JavaScript und CSS, um die Textfarbe zwischen Zeilen zu ändern_Javascript-Fähigkeiten

WBOY
Freigeben: 2016-05-16 15:33:53
Original
1192 Leute haben es durchsucht

Schauen wir uns zunächst eine einfache Methode an.
Definieren Sie in CSS zwei Stile .odd{...} und .even{...} für unterschiedliche Hintergrundfarben von Zeilen mit ungerader bzw. gerader Nummer. Verwenden Sie nach dem Laden der Webseite Javascript, um die Liste der zu ändernden Tags abzurufen, und führen Sie den folgenden Code aus:

// 当文件加载时,执行代码。
window.onload = function() {
 // 获取<ul id="list" />对象
 var list = document.getElementById('list');
 // 获取list下面的所有li
 var items = list.getElementsByTagName('li');
 // 遍历items
 for (var i = 0; i < items.length; i++) {
  var className = (i % 2 == 0) &#63; ' odd' : ' even';
  items[i].className += className; 
 }
}
Nach dem Login kopieren

Implementieren verschiedener Farben für verschiedene Zeilen, damit die Änderung vollständig im Frontend verarbeitet wird und nicht mit der Back-End-Logik verwechselt wird, was eine bessere Lösung ist.
Dann ist der Effekt der Implementierung dieses Codes im Wesentlichen wie folgt:

2015114150851266.png (760×261)

Allerdings gibt es bei diesem Ansatz einige Probleme:

  • Nur ​​eine angegebene Liste kann gerendert werden und kann nicht wiederverwendet werden
  • Sie können die Startposition der Verfärbung nicht angeben. Bei der Bearbeitung der Verfärbung müssen Sie eine spezielle Bearbeitung schreiben
  • Der gesamte Code befindet sich im Onload-Ereignis und die Abhängigkeit von der Seite ist zu hoch

Verbessern Sie den Code und verschieben Sie ihn in eine separate Funktion:

/**
 * 此方法用于列表的隔行变色效果,可以灵活得为指定ID的列表指定隔行的颜色。
 *
 * @param id 列表的id
 * @param item 要变色的行的标签
 * @param odd 奇数行的样式类名,如果不指定,则默认为odd
 * @param even 偶数行的样式类名,如果不指定,则默认为even
 * @param start 开始变色的行的索引,如果不指定,则默认为0
 * @param end 结束变色的行的索引,如果不指定,则默认为列表长度
 */
function rowRender(id, item, odd, even, start, end) {
 // 获取列表容器
 var list = document.getElementById(id);
 // 获取列表
 var items = list.getElementsByTagName(item);
 
 // 修正初始位置,如果不是一个数字或者越界,则从0开始
 if (isNaN(start) || (start < 0 || start >= items.length)) {
  start = 0;
 }
 
 // 修正结束位置,如果不是一个数字或者越界,则为列表末尾
 if (isNaN(end) || (end < start || end >= items.length)) {
  end = items.length;
 }
 
 // 如果没有指定odd,则默认为'odd'
 odd = odd || 'odd';
 // 如果没有指定even, 则默认为'even'
 even = even || 'even'; 
 
 // 遍历列表并渲染效果
 for (var i = start; i < end; i++) {
  var className = ' ' + ((i % 2 == 0) &#63; odd : even);
  items[i].className += className;
 }
}
Nach dem Login kopieren

Verwendung:

window.onload = function() {
 // 渲梁list1下所有的li标签,使用默认的样式和起始位置
 rowRender('list1', 'li');

 // 渲梁list2下所有的li标签,使用指定的odd和默认的even,使用指定的起始位置
 rowRender('list2', 'li', 'odd1', null, 2, 6);

 // 渲梁table1下所有的tr标签,使用指定的odd和even,使用默认的起始位置
 rowRender('table1', 'tr', 'tr-odd', 'tr-even');
 // 渲梁table2下所有的tr标签,使用指定的odd和even,使用指定的起始位置
 rowRender('table2', 'tr', 'tr-odd', 'tr-even', 1);
}

Nach dem Login kopieren

Beispiel:
Tabelle 1

rowRender('table1', 'tr', 'tr-odd', 'tr-even');
Nach dem Login kopieren

2015114151117861.png (182×292)

Tabelle 2

rowRender('table1', 'tr', 'tr-odd', 'tr-even', 1);
Nach dem Login kopieren

2015114151136246.png (131×308)

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage