javascript 技巧(一)

一. open 居中

 

function newWin(url){
	window.open(url, "newwindow", "width=600,height=500,top="+(screen.availHeight-500)/2+",left="+(screen.availWidth-600)/2+", toolbar=no, menubar=no, scrollbars=yes, resizable=no, location=no, status=no");
}

 

二. JavaScript 基础知识

 

        附件 JavaScript_Core_-_v0.pdf

 

 

三. JavaScript 刷新页面

Javascript刷新页面的几种方法:
1    history.go(0)
2    location.reload()
3    location=location
4    location.assign(location)
5    document.execCommand('Refresh')
6    window.navigate(location)
7    location.replace(location)
8    document.URL=location.href

自动刷新页面的方法:

1 .页面自动刷新:把如下代码加入<head>区域中

<meta http-equiv="refresh" content="20">

其中20指每隔20秒刷新一次页面.

2 .页面自动跳转:把如下代码加入<head>区域中

<meta http-equiv="refresh" content="20;url=http://www.wyxg.com">

其中20指隔20秒后跳转到http://www.wyxg.com页面

3 .页面自动刷新js版

<script language="JavaScript">
function myrefresh()
{
       window.location.reload();
}

setTimeout('myrefresh()',1000); //指定1秒刷新一次
</script>

 


JS刷新框架的脚本语句

//如何刷新包含该框架的页面用  

<script language=JavaScript>
   parent.location.reload();
</script> 

 

//子窗口刷新父窗口

<script language=JavaScript>
    self.opener.location.reload();
</script>

( 或 <a href="javascript:opener.location.reload()">刷新</a>   )

 


//如何刷新另一个框架的页面用  

<script language=JavaScript>
   parent.另一FrameID.location.reload();
</script>

 


//如果想关闭窗口时刷新或者想开窗时刷新的话,在<body>中调用以下语句即可。

<body onload="opener.location.reload()"> 开窗时刷新
<body onUnload="opener.location.reload()"> 关闭时刷新
<script language="javascript">
window.opener.document.location.reload()
</script>

 


//如果想在刷新时不弹出提示可以用:

window.location.href=window.location.href ;
window.location.reload;

 

但是window.location.href="要刷新的页面",在ie7中没有问题,在ie6和遨游中就不行,而window.location.reload()就可以,要多注意啦

 

<js基础>--javascript刷新页面

1.Response.Write("<script   language=javascript>parent.left.document.location.reload();</script>");
2.Response.Write("<script>window.top.location='login.aspx';window.close</script>");
3.this.RegisterStartupScript("reload","<script>window.parent.frames('left').location.reload(true);</script>");     或    this.RegisterStartupScript("reload","<script>window.parent.frames('left').location.href=window.parent.frames('left').location.href;</script>");

 

四. JavaScript  typeof()用法 

经常会在js里用到数组,比如 多个名字相同的input, 若是动态生成的, 提交时就需要判断其是否是数组.

if(document.mylist.length != "undefined" ) {} 这个用法有误.

正确的是 if( typeof(document.mylist.length) != "undefined" ) {}

或 if( !isNaN(document.mylist.length) ) {}

typeof的运算数未定义,返回的就是 "undefined".

运算数为数字 typeof(x) = "number"

字符串 typeof(x) = "string"

布尔值 typeof(x) = "boolean"

对象,数组和null typeof(x) = "object"

函数 typeof(x) = "function"

typeof 运算符返回一个用来表示表达式的数据类型的字符串。
可能的字符串有:"number"、"string"、"boolean"、"object"、"function" 和 "undefined"。
如:
alert(typeof (123));//typeof(123)返回"number"
alert(typeof ("123"));//typeof("123")返回"string"

typeof 运算符

返回一个用来表示表达式的数据类型的字符串。

typeof[()expression[]] ;

expression 参数是需要查找类型信息的任意表 达式。
说明

typeof 运算符把类型信息当作字符串返回。typeof 返回值有六种可能: "number," "string," "boolean," "object," "function," 和 "undefined."
typeof 语法中的圆括号是可选项。

 

 

五. JavaScript  js 中 html 对象删除

/**
   * @deprecated 关闭div 真正的从html中移除div代码,释放资源,兼容ie和火狐
   * 
   */
var divobj = creatElement("div");

   function closeDiv(divobj)
   {
    divobj.parentNode.removeChild(divobj);
   }

 

 

六. JavaScript  Event.observe

Event.observe('loginName', 'click', function (event) 用法

第一个参数是元素名。。。。。第二个参数是动作。。。。第三个参数是执行的函数。。。。

 

使用Event.observe可以更好地让页面元素与js代码分离,如下面的代码.

 

function init() {

Event.observe('loginName', 'click', function (event) {
   Event.element(event).select();
   $("loginName").value="";
});

var loginName = $("loginName") ;
loginName.style.color ="gray";

}

Event.observe(document, 'dom:loaded', init);

 

<html>  
<head>  
    <title>测试</title>  
    <script type="text/javascript" src="prototype-1.5.1.2.js"></script>  
</head>  
<body>  
请输入:<input type="text" name="birth" id="birth"/><br/>  
<input id="btn_test" type="button" value="测试" />  
</body>  
</html>  
<script type="text/javascript" language="javascript">  
                 Event.observe('btn_test', 'click', test);   
                 function test(){   
                     alert("弹出消息!!!");   
                 }   
</script>

 

 

七. JavaScript 判断 日期 时间 格式是否正确

function isDate(date) {
	if (typeof (date) == 'undefined' || date == null || date == '') {
		return false;
	}
	// 日期的分隔符
	var splitStr = '/';

	var strs = date.split(splitStr);

	var d = new Date(strs[0], strs[1] - 1, strs[2]);

	var year = d.getFullYear();
	var month = d.getMonth() + 1;
	var day = d.getDate();

	// 以十进制分割比较
	if (parseInt(strs[0], 10) == year && parseInt(strs[1], 10) == month
			&& parseInt(strs[2], 10) == day) {
		return true;
	} else {
		return false;
	}
}

 

 

八. JavaScript  计算日期加减

 某个日期 + 多少月多少天 = 某个日期的问题。至于,某个日期 - 某个日期 = 多少天

 

//解决IE下得到时间为NaN的情况
function parseISO8601(dateStringInRange) {
    var isoExp = /^s*(d{4})-(dd)-(dd)s*$/,
        date = new Date(NaN), month,
        parts = isoExp.exec(dateStringInRange);
    if(parts) {
      month = +parts[2];
      date.setFullYear(parts[1], month - 1, parts[3]);
      if(month != date.getMonth() + 1) {
        date.setTime(NaN);
      }
    }
    return date;
}
var change_date = function(dates,months,days) {
    var datestr = parseISO8601(dates);
    // 参数表示在当前日期下要增加的天数 
    var now = new Date(datestr);
    if(months != 0){
        now.setMonth(now.getMonth() + months);   
    }
    now.setDate((now.getDate()-1) + 1 * days);
    var year = now.getFullYear(); 
    if(months != 0){
        var month = now.getMonth()+1;
    }else{
        var month = now.getMonth()+1;
    }    
    var day = now.getDate(); 
    if (month < 10) { 
        month = '0' + month; 
    } 
    if (day < 10) { 
        day = '0' + day; 
    } 
    return year + '-' + month + '-' + day; 
}; 
var n = change_date("2012-12-01",12,32);
alert(n);

 

 

 javascript 中日期的加减运算.如今天 + 80天

 

function   DateAdd(interval,number,date)
{
/*
  *---------------   DateAdd(interval,number,date)   -----------------
  *   DateAdd(interval,number,date)  
  *   功能:实现VBScript的DateAdd功能.
  *   参数:interval,字符串表达式,表示要添加的时间间隔.
  *   参数:number,数值表达式,表示要添加的时间间隔的个数.
  *   参数:date,时间对象.
  *   返回:新的时间对象.
  *   var   now   =   new   Date();
  *   var   newDate   =   DateAdd( "d ",5,now);
  *   author:wanghr100(灰豆宝宝.net)
  *   update:2004-5-28   11:46
  *---------------   DateAdd(interval,number,date)   -----------------
  */
        switch(interval)
        {
                case   "y "   :   {
                        date.setFullYear(date.getFullYear()+number);
                        return   date;
                        break;
                }
                case   "q "   :   {
                        date.setMonth(date.getMonth()+number*3);
                        return   date;
                        break;
                }
                case   "m "   :   {
                        date.setMonth(date.getMonth()+number);
                        return   date;
                        break;
                }
                case   "w "   :   {
                        date.setDate(date.getDate()+number*7);
                        return   date;
                        break;
                }
                case   "d "   :   {
                        date.setDate(date.getDate()+number);
                        return   date;
                        break;
                }
                case   "h "   :   {
                        date.setHours(date.getHours()+number);
                        return   date;
                        break;
                }
                case   "m "   :   {
                        date.setMinutes(date.getMinutes()+number);
                        return   date;
                        break;
                }
                case   "s "   :   {
                        date.setSeconds(date.getSeconds()+number);
                        return   date;
                        break;
                }
                default   :   {
                        date.setDate(d.getDate()+number);
                        return   date;
                        break;
                }
        }
}

var   now   =   new   Date();
//加五天.
var   newDate   =   DateAdd( "d ",5,now);
alert(newDate.toLocaleDateString())
//加两个月.
newDate   =   DateAdd( "m ",2,now);
alert(newDate.toLocaleDateString())
//加一年
newDate   =   DateAdd( "y ",1,now);
alert(newDate.toLocaleDateString()) 

 

 

 

九. JavaScript  四舍五入 计算

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>Javascript四舍五入(Math.round()与Math.pow())</title>
    <script type="text/javascript">
        //Math.round(x);返回数字最接近的整数,四舍五入取整数,即舍去小数部分
        function f(){
            alert(Math.round(123.567));
            alert(Math.round(123.456));
        }
        //Math.pow(x,y);返回底数的指定次幂
        //返回以x的y次幂,等同于x的y次幂的数值表达式
        //如果pow的参数过大而引起浮点溢出,返回Infinity
        function f1(){
            alert(Math.pow(2,10));//2的10次方等于1024
            alert(Math.pow(1024,0.1));//1024的0.1次方等于2
            alert(Math.pow(99,9999));//溢出则返回Infinity
        }
        /*Javascript设置要保留的小数位数,四舍五入。
         *ForDight(Dight,How):数值格式化函数,Dight要格式化的 数字,How要保留的小数位数。
         *这里的方法是先乘以10的倍数,然后去掉小数,最后再除以10的倍数。
         */  
        function ForDight(Dight,How){  
            Dight = Math.round(Dight*Math.pow(10,How))/Math.pow(10,How);  
            return Dight;  
        }  
        function f2(){
            alert(ForDight(12345.67890,3));//保留三位小数
            alert(ForDight(123.99999,4));//保留四位小数
        }
        //另外一种四舍五入的方法,原理一样。
        //里面的两个参数:num就是要转换的数据。n为要转换的位数
        //cheng(123.456,2);//保留两位小数
        function cheng(num,n){
            var  dd=1;  
            var  tempnum;  
            for(i=0;i<n;i++){
                dd*=10;  
            }  
            tempnum = num*dd;
            tempnum = Math.round(tempnum);  
            alert(tempnum/dd);  
        }
    </script>
</head>
<body>
    <input type="button" value="round" onclick="f();" />
    <input type="button" value="pow" onclick="f1();" />
    <input type="button" value="设置要保留的小数位数,四舍五入" onclick="f2();" />
    <input type="button" value="cheng" onclick="cheng(123.456,2);" />
</body>
</html>

 

代码 



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

--><script type="text/javascript">
//用Javascript取float型小数点后两位,例22.127456取成22.13,如何做? 
//1.最笨的办法....... [我就怎么干的.........] 
    function get(){
        var s = 22.127456 + "";
        var str = s.substring(0,s.indexOf(".") + 3);
        alert(str);
    } 
</script>
<script type="text/javascript">
//2. 正则表达式效果不错 
    onload = function(){
        var a = "23.456322";
        var aNew;
        var re = /([0-9]+\.[0-9]{2})[0-9]*/;
        aNew = a.replace(re,"$1");
        alert(aNew);
    }
</script>

<script type="text/javascript">
//3. 他就比较聪明了..... 
    var num=22.127456;
    alert( Math.round(num*100)/100);
</script> 

<script type="text/javascript">
//4.会用新鲜东西的朋友....... 但是需要 IE5.5+才支持。 
//计算有问题
    var num=22.127456;
    alert( num.toFixed(2));
</script>

 

 

 

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(JavaScript)