📄 niceforms.js
字号:
/*#############################################################
Name: Niceforms
Version: 1.0
Author: Lucian Slatineanu
URL: http://www.badboy.ro/
Feel free to use and modify but please provide credits.
#############################################################*/
//Global Variables
var niceforms = document.getElementsByTagName('form'); var inputs = new Array(); var labels = new Array(); var radios = new Array(); var radioLabels = new Array(); var checkboxes = new Array(); var checkboxLabels = new Array(); var texts = new Array(); var textareas = new Array(); var selects = new Array(); var selectText = "please select"; var agt = navigator.userAgent.toLowerCase(); this.ie = ((agt.indexOf("msie") != -1) && (agt.indexOf("opera") == -1)); var hovers = new Array(); var buttons = new Array(); var isMac = new RegExp('(^|)'+'Apple'+'(|$)');
//Theme Variables - edit these to match your theme
var selectRightSideWidth = 21;
var selectLeftSideWidth = 8;
var selectAreaHeight = 21;
var selectAreaOptionsOverlap = 2;
var imagesPath = "images/";
//Initialization function - if you have any other 'onload' functions, add them here
function init() {
if(!document.getElementById) {return false;}
preloadImages();
getElements();
separateElements();
replaceRadios();
replaceCheckboxes();
replaceSelects();
if(!isMac.test(navigator.vendor)) {
replaceTexts();
replaceTextareas();
buttonHovers();
}
}
//preloading required images
function preloadImages() {
preloads = new Object();
preloads[0] = new Image(); preloads[0].src = imagesPath + "button_left_xon.gif";
preloads[1] = new Image(); preloads[1].src = imagesPath + "button_right_xon.gif";
preloads[2] = new Image(); preloads[2].src = imagesPath + "input_left_xon.gif";
preloads[3] = new Image(); preloads[3].src = imagesPath + "input_right_xon.gif";
preloads[4] = new Image(); preloads[4].src = imagesPath + "txtarea_bl_xon.gif";
preloads[5] = new Image(); preloads[5].src = imagesPath + "txtarea_br_xon.gif";
preloads[6] = new Image(); preloads[6].src = imagesPath + "txtarea_cntr_xon.gif";
preloads[7] = new Image(); preloads[7].src = imagesPath + "txtarea_l_xon.gif";
preloads[8] = new Image(); preloads[8].src = imagesPath + "txtarea_tl_xon.gif";
preloads[9] = new Image(); preloads[9].src = imagesPath + "txtarea_tr_xon.gif";
}
//getting all the required elements
function getElements() {
var re = new RegExp('(^| )'+'niceform'+'( |$)');
for (var nf = 0; nf < document.getElementsByTagName('form').length; nf++) {
if(re.test(niceforms[nf].className)) {
for(var nfi = 0; nfi < document.forms[nf].getElementsByTagName('input').length; nfi++) {inputs.push(document.forms[nf].getElementsByTagName('input')[nfi]);}
for(var nfl = 0; nfl < document.forms[nf].getElementsByTagName('label').length; nfl++) {labels.push(document.forms[nf].getElementsByTagName('label')[nfl]);}
for(var nft = 0; nft < document.forms[nf].getElementsByTagName('textarea').length; nft++) {textareas.push(document.forms[nf].getElementsByTagName('textarea')[nft]);}
for(var nfs = 0; nfs < document.forms[nf].getElementsByTagName('select').length; nfs++) {selects.push(document.forms[nf].getElementsByTagName('select')[nfs]);}
}
}
}
//separating all the elements in their respective arrays
function separateElements() {
var r = 0; var c = 0; var t = 0; var rl = 0; var cl = 0; var tl = 0; var b = 0;
for (var q = 0; q < inputs.length; q++) {
if(inputs[q].type == 'radio') {
radios[r] = inputs[q]; ++r;
for(var w = 0; w < labels.length; w++) {if(labels[w].htmlFor == inputs[q].id) {if(inputs[q].checked) {labels[w].className = "chosen";} radioLabels[rl] = labels[w]; ++rl;}}
}
if(inputs[q].type == 'checkbox') {
checkboxes[c] = inputs[q]; ++c;
for(var w = 0; w < labels.length; w++) {if(labels[w].htmlFor == inputs[q].id) {if(inputs[q].checked) {labels[w].className = "chosen";} checkboxLabels[cl] = labels[w]; ++cl;}}
}
if((inputs[q].type == "text") || (inputs[q].type == "password")) {texts[t] = inputs[q]; ++t;}
if((inputs[q].type == "submit") || (inputs[q].type == "button")) {buttons[b] = inputs[q]; ++b;}
}
}
function replaceRadios() {
for (var q = 0; q < radios.length; q++) {
//move radios out of the way
radios[q].className = "outtaHere";
//create div
var radioArea = document.createElement('div');
if(radios[q].checked) {radioArea.className = "radioAreaChecked";} else {radioArea.className = "radioArea";}
radioArea.style.left = findPosX(radios[q]) + 'px';
radioArea.style.top = findPosY(radios[q]) + 'px';
radioArea.style.margin = "1px";
radioArea.id = "myRadio" + q;
//insert div
radios[q].parentNode.insertBefore(radioArea, radios[q]);
//assign actions
radioArea.onclick = new Function('rechangeRadios('+q+')');
radioLabels[q].onclick = new Function('rechangeRadios('+q+')');
if(!this.ie) {radios[q].onfocus = new Function('focusRadios('+q+')'); radios[q].onblur = new Function('blurRadios('+q+')');}
radios[q].onclick = radioEvent;
}
return true;
}
function focusRadios(who) {
var what = document.getElementById('myRadio'+who);
what.style.border = "1px dotted #333"; what.style.margin = "0";
return false;
}
function blurRadios(who) {
var what = document.getElementById('myRadio'+who);
what.style.border = "0"; what.style.margin = "1px";
return false;
}
function checkRadios(who) {
var what = document.getElementById('myRadio'+who);
others = document.getElementsByTagName('div');
for(var q = 0; q < others.length; q++) {if((others[q].className == "radioAreaChecked")&&(others[q].nextSibling.name == radios[who].name)) {others[q].className = "radioArea";}}
what.className = "radioAreaChecked";
}
function changeRadios(who) {
if(radios[who].checked) {
for(var q = 0; q < radios.length; q++) {if(radios[q].name == radios[who].name) {radios[q].checked = false; radioLabels[q].className = "";}}
radios[who].checked = true; radioLabels[who].className = "chosen";
checkRadios(who);
}
}
function rechangeRadios(who) {
if(!radios[who].checked) {
for(var q = 0; q < radios.length; q++) {if(radios[q].name == radios[who].name) {radios[q].checked = false; radioLabels[q].className = "";}}
radios[who].checked = true; radioLabels[who].className = "chosen";
checkRadios(who);
}
}
function radioEvent(e) {
if (!e) var e = window.event;
if(e.type == "click") {for (var q = 0; q < radios.length; q++) {if(this == radios[q]) {changeRadios(q); break;}}}
}
function replaceCheckboxes() {
for (var q = 0; q < checkboxes.length; q++) {
//move checkboxes out of the way
checkboxes[q].className = "outtaHere";
//create div
var checkboxArea = document.createElement('div');
if(checkboxes[q].checked) {checkboxArea.className = "checkboxAreaChecked";} else {checkboxArea.className = "checkboxArea";}
checkboxArea.style.left = findPosX(checkboxes[q]) + 'px';
checkboxArea.style.top = findPosY(checkboxes[q]) + 'px';
checkboxArea.style.margin = "1px";
checkboxArea.id = "myCheckbox" + q;
//insert div
checkboxes[q].parentNode.insertBefore(checkboxArea, checkboxes[q]);
//asign actions
checkboxArea.onclick = new Function('rechangeCheckboxes('+q+')');
if(!isMac.test(navigator.vendor)) {checkboxLabels[q].onclick = new Function('changeCheckboxes('+q+')');}
else {checkboxLabels[q].onclick = new Function('rechangeCheckboxes('+q+')');}
if(!this.ie) {checkboxes[q].onfocus = new Function('focusCheckboxes('+q+')'); checkboxes[q].onblur = new Function('blurCheckboxes('+q+')');}
checkboxes[q].onkeydown = checkEvent;
}
return true;
}
function focusCheckboxes(who) {
var what = document.getElementById('myCheckbox'+who);
what.style.border = "1px dotted #333"; what.style.margin = "0";
return false;
}
function blurCheckboxes(who) {
var what = document.getElementById('myCheckbox'+who);
what.style.border = "0"; what.style.margin = "1px";
return false;
}
function checkCheckboxes(who, action) {
var what = document.getElementById('myCheckbox'+who);
if(action == true) {what.className = "checkboxAreaChecked";}
if(action == false) {what.className = "checkboxArea";}
}
function changeCheckboxes(who) {
if(checkboxLabels[who].className == "chosen") {
checkboxes[who].checked = true;
checkboxLabels[who].className = "";
checkCheckboxes(who, false);
}
else if(checkboxLabels[who].className == "") {
checkboxes[who].checked = false;
checkboxLabels[who].className = "chosen";
checkCheckboxes(who, true);
}
}
function rechangeCheckboxes(who) {
var tester = false;
if(checkboxLabels[who].className == "chosen") {
tester = false;
checkboxLabels[who].className = "";
}
else if(checkboxLabels[who].className == "") {
tester = true;
checkboxLabels[who].className = "chosen";
}
checkboxes[who].checked = tester;
checkCheckboxes(who, tester);
}
function checkEvent(e) {
if (!e) var e = window.event;
if(e.keyCode == 32) {for (var q = 0; q < checkboxes.length; q++) {if(this == checkboxes[q]) {changeCheckboxes(q);}}} //check if space is pressed
}
function replaceSelects() {
for(var q = 0; q < selects.length; q++) {
//create and build div structure
var selectArea = document.createElement('div');
var left = document.createElement('div');
var right = document.createElement('div');
var center = document.createElement('div');
var button = document.createElement('a');
var text = document.createTextNode(selectText);
center.id = "mySelectText"+q;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -