记录下开发过程中常用到的JS问题
1. 直接获取对性属性,更改值无效。
遇到的一个郁闷的问题,下面这样修改值居然无效。
需要这样写:
获取指定月的最后一天的日期
简单Map实现
//------------简单类似Map的功能 Start-----------//
去前后空格
判断undefined类型
删除节点
清除所有的ecForm的titleId
去除字符串或者数组的重复数据
1. 直接获取对性属性,更改值无效。
遇到的一个郁闷的问题,下面这样修改值居然无效。
- var idValue=document.getElementById("id").value;
- idValue="555";
var idValue=document.getElementById("id").value;
idValue="555";
需要这样写:
- var id=document.getElementById("id");
- id.value="555";
var id=document.getElementById("id");
id.value="555";
获取指定月的最后一天的日期
- function getLastDate(month, year){
- var ar = new Array(12);
- ar[0] = 31; // January
- ar[1] = (!leapYear(year)) ? 29 : 28; // February
- ar[2] = 31; // March
- ar[3] = 30; // April
- ar[4] = 31; // May
- ar[5] = 30; // June
- ar[6] = 31; // July
- ar[7] = 31; // August
- ar[8] = 30; // September
- ar[9] = 31; // October
- ar[10] = 30; // November
- ar[11] = 31; // December
- return ar[month-1];
- }
- function leapYear(year) {
- if (year % 4 == 0)
- return true;
- return false;
- }
function getLastDate(month, year){
var ar = new Array(12);
ar[0] = 31; // January
ar[1] = (!leapYear(year)) ? 29 : 28; // February
ar[2] = 31; // March
ar[3] = 30; // April
ar[4] = 31; // May
ar[5] = 30; // June
ar[6] = 31; // July
ar[7] = 31; // August
ar[8] = 30; // September
ar[9] = 31; // October
ar[10] = 30; // November
ar[11] = 31; // December
return ar[month-1];
}
function leapYear(year) {
if (year % 4 == 0)
return true;
return false;
}
简单Map实现
//------------简单类似Map的功能 Start-----------//
- function Map() {
- var struct = function(key, value) {
- this.key = key;
- this.value = value;
- }
- var put = function(key, value){
- for (var i = 0; i < this.arr.length; i++) {
- if ( this.arr[i].key === key ) {
- this.arr[i].value = value;
- return;
- }
- }
- this.arr[this.arr.length] = new struct(key, value);
- }
- var get = function(key) {
- for (var i = 0; i < this.arr.length; i++) {
- if ( this.arr[i].key === key ) {
- return this.arr[i].value;
- }
- }
- return '';
- }
- var remove = function(key) {
- var v;
- for (var i = 0; i < this.arr.length; i++) {
- v = this.arr.pop();
- if ( v.key === key ) {
- continue;
- }
- this.arr.unshift(v);
- }
- }
- var size = function() {
- return this.arr.length;
- }
- var isEmpty = function() {
- return this.arr.length <= 0;
- }
- this.arr = new Array();
- this.get = get;
- this.put = put;
- this.remove = remove;
- this.size = size;
- this.isEmpty = isEmpty;
- }
- //------------简单类似Map的功能 end-----------//
function Map() {
var struct = function(key, value) {
this.key = key;
this.value = value;
}
var put = function(key, value){
for (var i = 0; i < this.arr.length; i++) {
if ( this.arr[i].key === key ) {
this.arr[i].value = value;
return;
}
}
this.arr[this.arr.length] = new struct(key, value);
}
var get = function(key) {
for (var i = 0; i < this.arr.length; i++) {
if ( this.arr[i].key === key ) {
return this.arr[i].value;
}
}
return '';
}
var remove = function(key) {
var v;
for (var i = 0; i < this.arr.length; i++) {
v = this.arr.pop();
if ( v.key === key ) {
continue;
}
this.arr.unshift(v);
}
}
var size = function() {
return this.arr.length;
}
var isEmpty = function() {
return this.arr.length <= 0;
}
this.arr = new Array();
this.get = get;
this.put = put;
this.remove = remove;
this.size = size;
this.isEmpty = isEmpty;
}
//------------简单类似Map的功能 end-----------//
去前后空格
- function trim(s){
- return s.relace(/^/s*/,' ').relace(//s*$/,' ');
- }
function trim(s){
return s.relace(/^/s*/,' ').relace(//s*$/,' ');
}
判断undefined类型
- var exp = undefined;
- if (typeof(exp) == "undefined") {
- alert("undefined");}
var exp = undefined;
if (typeof(exp) == "undefined") {
alert("undefined");}
删除节点
- xxx.removeChild(obj) xxx是所删除节点的父节点
- xxx.removeNode(true) xxx是所要删除的节点(IE支持)
- object.parentNode.removeChild(object) (firefox支持)
xxx.removeChild(obj) xxx是所删除节点的父节点
xxx.removeNode(true) xxx是所要删除的节点(IE支持)
object.parentNode.removeChild(object) (firefox支持)
清除所有的ecForm的titleId
- function clear(tagsName){
- var allInput=document.getElementsByName(tagsName);
- for(var i=allInput.length-1;i>=0;i--){
- if(allInput[i].type=='hidden'){
- allInput[i].parentNode.removeChild(allInput[i]);
- }
- }
- }
- 这里循环需要倒序。
function clear(tagsName){
var allInput=document.getElementsByName(tagsName);
for(var i=allInput.length-1;i>=0;i--){
if(allInput[i].type=='hidden'){
allInput[i].parentNode.removeChild(allInput[i]);
}
}
}
这里循环需要倒序。
去除字符串或者数组的重复数据
- function getUnique(str){
- if(str==""){
- return str;
- }
- var strAry=str.split(",") ;
- return unique(strAry).join(",");
- }
- function unique(data){
- data = data || [];
- var a = {};
- for (var i=0; i<data.length; i++) {
- var v = data[i];
- if (typeof(a[v]) == 'undefined'){
- a[v] = 1;
- }
- };
- data.length=0;
- for (var i in a){
- data[data.length] = i;
- }
- return data;
- }
function getUnique(str){
if(str==""){
return str;
}
var strAry=str.split(",") ;
return unique(strAry).join(",");
}
function unique(data){
data = data || [];
var a = {};
for (var i=0; i<data.length; i++) {
var v = data[i];
if (typeof(a[v]) == 'undefined'){
a[v] = 1;
}
};
data.length=0;
for (var i in a){
data[data.length] = i;
}
return data;
}