共通JavaScript関数1-15(自己まとめ)
20831 ワード
一般的なJavaScript関数16-30(自己まとめ)
共通JavaScript関数31-46(自己まとめ)
1、画像サイズを調整して、形が崩れない(FFIE互換)/カット画像(overflow:hidden)
2、textarea領域の文字数を制御する
3、クリックして新しいウィンドウを表示する
4、inputボックスが自動的に内容に従って長くなる
5、お気に入りの追加
6、トップページの設定
7、Jquery+Ajaxはユーザーが存在するかどうかを判断する
8、メール形式が正しいかどうかを判断する
9、総合的にユーザー名を判断する(長さ、英語フィールドなど)
10、ニュースのスクロール
11、正の整数(shopping cart使用)または正の数(正の整数と正の小数)のみ入力可能
12、文字列を数字に変換する
13.ファイル形式を判断する(ファイル接尾辞を取得する)
14、切り取り文字列
15、文字列の分割
1、画像のサイズを調整し、形が崩れない(FFIE互換)
オーバーフロー:hiddenによる切り取り:
例:
2、textarea領域の文字数を制御する
3、クリックして新しいウィンドウを表示する
残念なことに、多くのブラウザはポップアップウィンドウを遮断します.手動で確認する必要があります.次は強制ポップアップウィンドウで、原理はformを作成して、postを通じて、開けて、ははは、原理はとても簡単です~
もちろんもっと良い方法は
詳細は、JAvascript基礎入門
4、inputボックスが自動的に内容に従って長くなる
5、お気に入りの追加
6、トップページの設定
7、Jquery+Ajaxはユーザーが存在するかどうかを判断する
または
8、メール形式が正しいかどうかを判断する
9、総合的にユーザー名を判断する(長さ、英語フィールドなど)
10、ニュースのスクロール
11、正の整数のみ入力可能(shopping cart使用)
または正数
12、文字列を数字に変換する
13.ファイル形式を判断する(ファイル接尾辞を取得する)
14、切り取り文字列
15、文字列の分割
転帖明記:http://justcoding.iteye.com/blog/548591
共通JavaScript関数31-46(自己まとめ)
1、画像サイズを調整して、形が崩れない(FFIE互換)/カット画像(overflow:hidden)
2、textarea領域の文字数を制御する
3、クリックして新しいウィンドウを表示する
4、inputボックスが自動的に内容に従って長くなる
5、お気に入りの追加
6、トップページの設定
7、Jquery+Ajaxはユーザーが存在するかどうかを判断する
8、メール形式が正しいかどうかを判断する
9、総合的にユーザー名を判断する(長さ、英語フィールドなど)
10、ニュースのスクロール
11、正の整数(shopping cart使用)または正の数(正の整数と正の小数)のみ入力可能
12、文字列を数字に変換する
13.ファイル形式を判断する(ファイル接尾辞を取得する)
14、切り取り文字列
15、文字列の分割
1、画像のサイズを調整し、形が崩れない(FFIE互換)
// <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;
}
}
}
}
オーバーフロー: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、メール形式が正しいかどうかを判断する
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