`
天梯梦
  • 浏览: 13747281 次
  • 性别: Icon_minigender_2
  • 来自: 洛杉矶
社区版块
存档分类
最新评论

常用JavaScript函数 1 - 15 (自我总结)

阅读更多

常用JavaScript函数 16 - 30(自我总结)

常用JavaScript函数 31- 46 (自我总结)

1、  调整图片大小,不走形(FF IE 兼容)/ 剪切图片(overflow:hidden)

2、  控制textarea区域文字数量

3、  点击显示新窗口

4、  input框自动随内容自动变长

5、  添加收藏夹

6、  设置首页

7、  Jquery + Ajax 判断用户是否存在

8、  判断email格式是否正确

9、  综合判断用户名(长度,英文字段等)

10、新闻滚动

11、 只允许输入正整数 (shopping cart 使用) 或者 正数 (正整数和正小数)

12、 转换字符串为数字

13、 判断文件格式(获得文件后缀)

14、 截取字符串

15、分割字符串

 

1、 调整图片大小,不走形(FF IE 兼容)

// 用法 <img src="this_image_path.jpg" onload="DrawImage(this,450,450);" />

	function DrawImage(ImgD,FitWidth,FitHeight){
		var image=new Image();
		image.src=ImgD.src;
		if(image.width>0 && image.height>0){
			if(image.width/image.height>= FitWidth/FitHeight){
				if(image.width>FitWidth){
					ImgD.width=FitWidth;
					ImgD.height=(image.height*FitWidth)/image.width;
				}else{
					ImgD.width=image.width;
					ImgD.height=image.height;
				}
			} else{
				if(image.height>FitHeight){
					ImgD.height=FitHeight;
					ImgD.width=(image.width*FitHeight)/image.height;
				}else{
					ImgD.width=image.width;
					ImgD.height=image.height;
				}
			}
		}
	}

 

通过 overflow:hidden进行剪切:

function clipImage(o, w, h){ 
	var img = new Image(); 
	img.src = o.src; 
	if(img.width >0 && img.height>0) 
	{ 
		if(img.width/img.height >= w/h) 
		{ 
			if(img.width > w) 
			{            
				o.width = (img.width*h)/img.height; 
				o.height = h; 
				//o.setAttribute("style", "marginLeft:-" + ((o.width-w)/2).toString() + "px");
				$(o).css("margin-left", "-"+((o.width-w)/2).toString() + "px");
			} 
			else 
			{ 
				o.width = img.width; 
				o.height = img.height; 
			}            
		} 
		else 
		{ 
			if(img.height > h) 
			{ 
				o.height = (img.height*w)/img.width; 
				o.width = w; 
				//o.setAttribute("style", "margin-top:-" + ((o.height-h)/2).toString() + "px");
				//$(o).css("style", "margin-top:-" + ((o.height-h)/2).toString() + "px");
				$(o).css("margin-top", "-"+((o.height-h)/2).toString() + "px");
		} 
			else 
			{ 
				o.width = img.width; 
				o.height = img.height; 
			}           
		} 
	}
} 

 

实例:

<style type="text/css">
	ul{list-style:none;}
	ul li{float:left;padding:1px;border:#ccc 1px solid;width:120px;height:120px;overflow:hidden;text-align:center;over-flow:hidden;}
</style>
<ul>	
	<li><img src="1.jpg" onload="DrawImage(this,120,120);" /></li>
	<li><img src="2.jpg" onload="clipImage(this,120,120);" /></li>
</ul>

 

2、控制textarea区域文字数量

<script>
/**
 * Calculate how many characters remain in a textarea (jQuery)
 * @param string textarea
 * @param int maxLength
 * @param string div
 */
function charsRemain(textarea, maxLength, div) {
	var currentLength = $(textarea).val().length;
 
	var charsLeft = maxLength - currentLength;
	if (charsLeft < 0) { charsLeft = 0; }
 
	$("#"+ div +"_charsRemain").html(charsLeft);
 
	if (currentLength > maxLength) {
		var fullText = $(textarea).val().substring(0, maxLength);
		$(textarea).val(fullText);
	}
}

/**
 * Calculate how many characters remain in a textarea (javascript)
 * @param string textarea
 * @param int maxLength
 * @param string div
 */
function charsRemain(textarea, maxLength, div) {
	var currentLength = textarea.value.length;
 
	var charsLeft = maxLength - currentLength;
	if (charsLeft < 0) { charsLeft = 0; }
 
	document.getElementById(div +"_charsRemain").innerHTML = charsLeft;
 
	if (currentLength > maxLength) {
		var fullText = textarea.value.substring(0, maxLength);
		textarea.value = fullText;
	}
}
</script>

<textarea rows="5" cols="15" onkeyup="charsRemain(this, 250, 'textarea');"></textarea>

<span id="textarea_charsRemain">250</span> characters remaining

 

 

3、点击显示新窗口

//弹窗
function g_OpenWindow(pageURL, innerWidth, innerHeight)
{	
	var ScreenWidth = screen.availWidth
	var ScreenHeight = screen.availHeight
	var StartX = (ScreenWidth - innerWidth) / 2
	var StartY = (ScreenHeight - innerHeight) / 2
	var wins = window.open(pageURL, 'OpenWin', 'left='+ StartX + ', top='+ StartY + ', Width=' + innerWidth +', height=' + innerHeight + ', resizable=yes, scrollbars=yes, status=no, toolbar=no, menubar=no, location=no')
	wins.focus();
}
<script language="JavaScript">
	// 自动弹出窗口
	var whatsNew = open('','_blank','top=50,left=50,width=200,height=300,' + 'menubar=no,toolbar=no,directories=no,location=no,' + 'status=no,resizable=no,scrollbars=yes');
		whatsNew.document.write('<center><b>news</b>< /center>');
		whatsNew.document.write('<p>this is a test');
		whatsNew.document.write('<p>deos address');
		whatsNew.document.write('<p align="right">' + '<a href="javascript:self.close()">Close</a>');
		whatsNew.document.close();
</script>

 

不幸的是,很多浏览器会屏蔽弹出窗口,你需要手动允许后方可看到!下面是强制弹出窗口,原理就是创建一个form,通过post,打开,哈哈,原理很简单~

  <script language="javascript">  
	  function ForceWindow (){  
		  this.r = document.documentElement;  
		  this.f = document.createElement("FORM");  
		  this.f.target   =   "_blank";  
		  this.f.method   =   "post";  
		  this.r.insertBefore(this.f, this.r.childNodes[0]);  //XML DOM : insertBefore() 方法可在已有的子节点前插入一个新的子节点。 insertBefore(newchild,refchild)
	  }   
	  
	  ForceWindow.prototype.pop = function (sUrl){  
		  this.f.action = sUrl;  
		  this.f.submit();  
	  }  

	  window.force  = new ForceWindow();  
  </script>  
   
  <body onLoad="window.force.pop('http://deographics.com/')">  
	  <div>
		this is a test ! we will open the deographics's website~~
	  </div>
  </body>  

 

当然还有更好的办法就是

<script>
	function openWin(){
	  window.showModalDialog(url,window, "help:no;scroll:no;resizable:no;status:0;dialogWidth:420px;dialogHeight:200px;center:yes");
	}
</script>

 

 更多请看:javascript基础入门

 

4、input框自动随内容自动变长

// input auto length
	// <input name="words" size="2" maxlength="100" onkeyup="checkLength(this)"/><span id="char">0</span>

	function checkLength(which) {
	   var maxchar=100;
	   //var oTextCount = document.getElementById("char");  
	   iCount = which.value.replace(/[^\u0000-\u00ff]/g,"aa").length;
	   if(iCount<=maxchar){
		   //oTextCount.innerHTML = "<font color=#FF0000>"+ iCount+"</font>";
		   which.style.border = '1px dotted #FF0000';
		   which.size=iCount+2;
	   }else{
		   alert('Please input letter less than '+ maxchar);
	   }
	}

 

5、添加收藏夹

// addfavorite
	function addfavorite(){
		if (document.all){
			window.external.addFavorite('http://deographics.com/','deographics');
		}else if (window.sidebar){
			window.sidebar.addPanel('deographics', 'http://deographics.com/', "");
		}
	}
	

 

6、设置首页

// setHomepage
	function  setHomepage(){   
		if(document.all){
			document.body.style.behavior  = 'url(#default#homepage)';
			document.body.setHomePage('http://deographics.com/');
		}else if(window.sidebar){
			if(window.netscape){
				try{
					netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
				}catch(e){
					alert(" The operation was refused by browser,if you want to enable this feature, please enter in the address column 'about:config', then, change 'signed.applets.codebase_principal_support' to 'true' ");
				}
			}
			var  prefs  =  Components.classes['@mozilla.org/preferences-service;1'].getService(Components.interfaces.nsIPrefBranch);
			prefs.setCharPref('browser.startup.homepage','http://deographics.com/');
		}
	}

 

7、Jquery + Ajax 判断用户是否存在

	// 检测 用户名是否存在
	$("#username").blur(function(){
		var name = $(this).val(); var table = $(this).attr('title'); 
		if(name!=''){
			var dataString = 'username='+ name + '&table=' + table; 
			$.post("operate.php",dataString,function(data){  //alert(data);
				if(data==0){
					alert('This username already exist !'); $(this).val('').focus(); return false;
				}
			});
		}
	});

 

或者

	var datastring = 'id=' + $id + '&pos=' + $pos;
	$.ajax({
		type: "POST",
		url: url,
		data: dataString,
		beforeSend: function(){},
		error: function(){alert('Send Error !');},
		success: function(data) {
			// do something
	   	}
	 });

 

8、 判断email格式是否正确

	function chekemail(temail){  
		 var pattern = /^[\w]{1}[\w\.\-_]*@[\w]{1}[\w\-_\.]*\.[\w]{2,4}$/i;  
		 if(pattern.test(temail)){return true;}else{return false;}  
	} 
	

 

9、综合判断用户名(长度,英文字段等)

// 实例

       var username = $('#username');
	var backValue = VerifyInput('username');

	if(backValue == 'length'){
		alert("Username is make up of 3 - 15 characters!"); 
                username.focus(); 
                return false;
	}else if(backValue == 'first'){
		alert("the First character must be letter or number !"); 
                username.focus(); 
                return false;
	}else if(backValue == 'back'){
		alert("Username only contains letter number or '_' "); 
                username.focus(); 
                return false;
	}

// 判断 
	
	function VerifyInput(user){
		var strUserID = $('#'+user).val();
		if (strUserID.length < 3 || strUserID.length > 15){ 
	   		return 'length'; 
		}else{
			for (nIndex=0; nIndex<strUserID.length; nIndex++){
			   cCheck = strUserID.charAt(nIndex);
			   if ( nIndex==0 && ( cCheck =='-' || cCheck =='_') ){
                                 return 'first';
                           }
			   if (!(IsDigit(cCheck) || IsAlpha(cCheck) || cCheck=='-' || cCheck=='_' )){
                                 return 'back';
                           }
			}
		}
	}

	function IsDigit(cCheck) {return (('0'<=cCheck) && (cCheck<='9'));}
	function IsAlpha(cCheck) {return ((('a'<=cCheck) && (cCheck<='z')) || (('A'<=cCheck) && (cCheck<='Z')))}


 

10、新闻滚动

<style type="text/css">
ul,li{margin:0;padding:0;font-size:12px;color:#999;}
ul{height:100px;overflow:hidden;}
ul li{line-height:20px;height:20px;}
</style>
   
<ul id="news">
	<li>New York web design Inc.1</li>
	<li>Your site will be structured 2</li>
	<li>hat will communicate the 3</li>

	<li>hat will communicate the  4</li>
	<li>hat will communicate the 5</li>
	<li>hat will communicate the  6</li>
	<li>hat will communicate the 7</li>
	<li>hat will communicate the 8</li>
	<li>hat will communicate the 9</li>

	<li>New York web design Inc. 10</li>
	<li>New York web design Inc.11</li>
	<li>New York web design Inc. 12</li>
	<li>New York web design Inc. 13</li>
	<li>New York web design Inc. 14</li>
</ul>

 

// 用法 : 四个参数分别是:操作对象, 停留时间,相对速度(越小越快),每次滚动多少(最好和Li的Line-height一致)。

scroll('news', 3000, 1, 20 );

function scroll(element, delay, speed, lineHeight) {
	var numpergroup = 5;
	var slideBox = (typeof element == 'string')?document.getElementById(element):element;
	var delay = delay||1000;
	var speed=speed||20;
	var lineHeight = lineHeight||20;
	var tid = null, pause = false;
	var liLength = slideBox.getElementsByTagName('li').length;
	var lack = numpergroup-liLength%numpergroup;
	for(i=0;i<lack;i++){
	slideBox.appendChild(document.createElement("li"));
	}
	var start = function() {
		 tid=setInterval(slide, speed);
	}
	var slide = function() {
		 if (pause) return;
		 slideBox.scrollTop += 2;
		 if ( slideBox.scrollTop % lineHeight == 0 ) {
				clearInterval(tid);
				for(i=0;i<numpergroup;i++){
					slideBox.appendChild(slideBox.getElementsByTagName('li')[0]);
				}
				slideBox.scrollTop = 0;
				setTimeout(start, delay);
		 }
	}
	slideBox.onmouseover=function(){pause=true;}
	slideBox.onmouseout=function(){pause=false;}
	setTimeout(start, delay);
}

 

11、只允许输入正整数 (shopping cart 使用)

<script language="JavaScript" type="text/javascript">
function checkNum(obj){
	var re = /^[1-9]\d*$/;
	if (!re.test(obj.value)){
        alert("只允许正整数!");
		obj.value='';
        obj.focus();
        return false;
     }
}
</script>

<input name="rate" type="text"onkeyup="checkNum(this)" />

 

或 正数 

<script language="JavaScript" type="text/javascript">
	function clearNoNum(obj)
	{
		//先把非数字的都替换掉,除了数字和.
		obj.value = obj.value.replace(/[^\d.]/g,"");
		//必须保证第一个为数字而不是.
		obj.value = obj.value.replace(/^\./g,"");
		//保证只有出现一个.而没有多个.
		obj.value = obj.value.replace(/\.{2,}/g,".");
		//保证.只出现一次,而不能出现两次以上
		obj.value = obj.value.replace(".","$#$").replace(/\./g,"").replace("$#$",".");
	}
</script>

只能输入数字和小数点的文本框:<input id="input1" onkeyup="clearNoNum(this)">

 

12、 转换字符串为数字

/*
js提供了parseInt()和parseFloat()两个转换函数。前者把值转换成整数,后者把值转换成浮点数。只有对String类型调用这些方法,这两个函数才能正确运行;对其他类型返回的都是NaN(Not a Number)。
*/

parseInt("1234blue");   //returns   1234
parseInt("0xA");   //returns   10
parseInt("22.5");   //returns   22
parseInt("blue");   //returns   NaN

parseFloat("1234blue");   //returns   1234.0
parseFloat("0xA");   //returns   NaN
parseFloat("22.5");   //returns   22.5
parseFloat("22.34.5");   //returns   22.34
parseFloat("0908");   //returns   908
parseFloat("blue");   //returns   NaN

/*
还可使用强制类型转换(type casting)处理转换值的类型。使用强制类型转换可以访问特定的值,即使它是另一种类型的。
Boolean(value)——把给定的值转换成Boolean型;
Number(value)——把给定的值转换成数字(可以是整数或浮点数);
String(value)——把给定的值转换成字符串。
*/

Boolean("");   //false   –   empty   string
Boolean("hi");   //true   –   non-empty   string
Boolean(100);   //true   –   non-zero   number
Boolean(null);   //false   -   null
Boolean(0);   //false   -   zero
Boolean(new   Object());   //true   –   object

Number(false)  0
Number(true)  1
Number(undefined) NaN
Number(null)  0
Number( "5.5 ")  5.5
Number( "56 ")  56
Number( "5.6.7 ") NaN
Number(new   Object())  NaN
Number(100)  100 

var   s1   =   String(null);   //"null"
var   oNull   =   null;
var   s2   =   oNull.toString();   //won’t   work,   causes   an   error

 

13、 判断文件格式(获得文件后缀)

    // 用法:get_ext(this,'img');  

    function get_ext(name){
        var pos = name.lastIndexOf('.');
        var extname = name.substring(pos,name.length) // like: str.split('.')
        var lastname = extname.toLowerCase();

       if (lastname !='.jpg' && lastname !='.gif' && lastname !='.png' && lastname !='.bmp'){
                return lastname;
        }else{
                return name;
            }
        }
    }

 

14、截取字符串

// 简单型

<script type="text/javascript">

var str="Hello world!"
document.write(str.substr(3,7))

</script>

//  结果是   lo worl


// 复杂型(中文或者中英文混合截取)

<script> 
//截取字符串 包含中文处理 
//(串,长度,增加...) 
function subString(str, len, hasDot) 
{ 
    var newLength = 0; 
    var newStr = ""; 
    var chineseRegex = /[^\x00-\xff]/g; 
    var singleChar = ""; 
    var strLength = str.replace(chineseRegex,"**").length; 
    for(var i = 0;i < strLength;i++) 
    { 
        singleChar = str.charAt(i).toString(); 
        if(singleChar.match(chineseRegex) != null) 
        { 
            newLength += 2; 
        }     
        else 
        { 
            newLength++; 
        } 
        if(newLength > len) 
        { 
            break; 
        } 
        newStr += singleChar; 
    } 
     
    if(hasDot && strLength > len) 
    { 
        newStr += "..."; 
    } 
    return newStr; 
} 

document.write(subString("你好,this is a test!",10,1));   //  参数依次为 字符串, 截取的长度 和 是否显示省略号
</script>

 

15、分割字符串

<script type="text/javascript">

var str = 'this_is_a_test_!';
var arr = str.split('_');

document.write(arr + "<br />");    // 罗列全部
document.write(arr[0] + "<br />"); // 取单项

</script>

 

 

转帖注明: http://justcoding.iteye.com/blog/548591

2
0
分享到:
评论

相关推荐

    常用JavaScript函数 16 - 30(自我总结)

    这篇自我总结涵盖了JavaScript函数的16到30个常用知识点,旨在帮助开发者更好地理解和应用这些功能强大的工具。 1. **数组操作** - `slice()`:用于从原数组中提取一个子数组并返回,不会改变原数组。 - `splice...

    javascript手册+php常用函数

    这份资源包含了一个 JavaScript 手册和一个 PHP 常用函数的参考文档,对于初学者和经验丰富的开发者来说,都是宝贵的参考资料。 JavaScript 手册: JavaScript 是一种轻量级的解释型编程语言,主要用于网页和网络...

    javascript延时执行跳转或执行函数

    1. `setTimeout`函数:这是一个内建的JavaScript函数,用于在指定的毫秒数后调用一个函数或执行某段代码。其基本语法是`setTimeout(function, delay)`, 其中`function`是要执行的函数,`delay`是延迟的时间,单位为...

    javascript常用函数归纳整理

    本文将深入探讨在JavaScript中的一些常用函数,这些函数涵盖了数据操作、字符串处理、日期处理、加密解密以及基本的验证功能。 1. 类型检查与数组判断: 在JavaScript中,`typeof`用于检测变量的类型,对于数组,`...

    匿名函数的一点知识

    ### 知识点:匿名函数在JavaScript中的应用与特性 #### 标题解析:“匿名函数的一点知识” 标题“匿名函数的一点知识”简洁明了地指出本文将围绕JavaScript中的匿名函数进行讲解,旨在帮助读者深入理解匿名函数的...

    Javascript基础教程(文字版,代码可复制)

    - **理解能力与自我实践**: 高效学习JavaScript的关键在于理解和实践相结合。建议在学习理论的同时多动手编写代码,尝试解决实际问题。 - **参考资源**: 除了本教程外,还可以参考MSDN和Netscape网站提供的官方文档...

    6.0S2JavaScript阶段测试机试题

    1. **基本概念**:JavaScript是一种解释型、弱类型、动态类型的脚本语言,主要用于网页和网络应用的开发。它通常与HTML和CSS一起使用,构建交互式的网页。 2. **变量与数据类型**:JavaScript支持var、let和const...

    JavaScript函数、方法、对象代码

    else return x*fact(x-1); }; 函数的参数数组:Arguments对象。常用arguments[i]引用,arguments.length等。 对象: 对象定义(函数)中的方法,其实也是个函数,与嵌套函数不同点在于:通过关键字this引用对象实体...

    TALLER-JAVASCRIPT-:TALLER 1 DE JAVASCRIPT

    描述与标题相同,"TALLER-JAVASCRIPT-:TALLER 1 DE JAVASCRIPT",这通常意味着提供的内容是针对JavaScript初学者的一个系列教程的第一部分,可能包括基本语法、数据类型、控制结构、函数等方面的实践练习。...

    JavaScript参考教程

    ### JavaScript参考教程知识点总结 #### 一、教程性质与适用对象 - **初级教程属性**:本教程适合初学者,提供了必要的基础知识,但对于高级特性如动态网页开发等内容涉及较少。 - **参考教程特性**:教程内容组织...

    一个使用JavaScript写的星际争霸网页游戏!超牛..纯JavaScript,值得研究

    在互联网技术日新月异的今天,JavaScript作为浏览器端最常用的语言,其应用领域已经远远超出最初的网页交互。这篇内容将深入探讨一个用JavaScript编写的星际争霸网页游戏,揭示其背后的编程思想和技术实现。 首先,...

    AJAX入门之深入理解JavaScript中的函数

    这是JavaScript函数式编程的一个重要特性。每个函数都是`Function`类型的实例,这与JavaScript中的内置对象(如`Date`、`Array`、`String`)类似,它们都是内部对象,由JavaScript引擎直接管理。 函数对象与其他...

    javaScript教学从入门到精通案例大集合(包含讲义文档,案例源码,内容共十二章)

    1. **基础语法**:在第一部分,你将学习JavaScript的基础语法,包括变量、数据类型(如字符串、数字、布尔值、对象、数组等)、控制流(如条件语句、循环结构)以及函数的使用。 2. **DOM操作**:JavaScript能够与...

    javaScript授课计划.doc

    1. **JavaScript简介**:介绍JavaScript的基本概念和运行环境,通过实例让学生了解其作用。 2. **JavaScript编程基础**:讲解数据类型、变量、表达式、运算符、基本语句、函数和对象,为后续学习打下基础。 3. **...

    JavaScript源代码集.rar

    这个"JavaScript源代码集.rar"文件包含了一系列的JavaScript源码实例,为学习者提供了丰富的实践素材,无论是教学还是自我提升,都能从中获益匪浅。下面我们将深入探讨JavaScript的一些关键知识点。 1. **基础语法*...

    javascript超详尽学习资料(源码,教材,ppt)

    1. 首先,通读教材,了解JavaScript的基本语法和核心概念。 2. 然后,结合PPT深入学习,理解实际应用中的场景和技巧。 3. 阅读源码,分析并尝试理解不同项目的实现方式,提高代码阅读能力。 4. 完成章节练习和课后...

    JavaScript 权威指南第四版(一)

    总之,《JavaScript 权威指南》第四版的“第一部分”为初学者提供了一个坚实的起点,通过学习这部分内容,读者可以理解JavaScript的基本语法和常用特性,为进一步深入学习和实践打下坚实基础。对于那些希望通过自我...

    javascript基础课件

    这个"javascript基础课件"涵盖了初学者需要掌握的关键概念,是进行日常教学和自我学习的理想资源。以下是一些主要的知识点,它们通常会出现在这样的课件中: 1. **变量与数据类型**:JavaScript中的变量可以用来...

    java script visual quick start

    该书是一本面向新手的学习指南,旨在帮助读者快速掌握JavaScript的基础知识和常用技巧。作为一本入门级教材,它通过直观的视觉示例和易于理解的语言来讲解JavaScript的核心概念和技术。 ### 二、书籍内容特点 ####...

    javascript资料大全

    1. **JavaScript教程(最新中文版).rar**: 这个文件可能是JavaScript的最新中文教程,涵盖了从基础到高级的各种主题。可能包括变量、数据类型、控制结构(如条件语句和循环)、函数、对象、数组、字符串处理、...

Global site tag (gtag.js) - Google Analytics