几个高效,简洁的字符处理函数_javascript技巧
都是基于 String.prototype 的扩展:
起因是有个网友和我讨论两个函数,
一个是 isDateTime (判断字符是否是符合 yyyy-mm-dd hh:mm:ss日期格式)
另一个是 left 函数,类似vbscript的left 实现中英文字符的混合截取。
他两个函数都用了循环,还用了N多 if 语句,每个函数都超过了40行代码,问我有无好的办法精简一下。
于是,我就写出了下面的代码,不敢说最效率最高,但是已经是够精简了, left函数才1行
1 <script> <BR> 2 <BR> 3 //by Go_Rush(阿舜) from http://ashun.cnblogs.com/ <BR> 4 <BR> 5 function $A(arrayLike){ <BR> 6 for(var i=0,ret=[];i<arrayLike.length;i++) ret.push(arrayLike[i]) <BR> 7 return ret <BR> 8 }; <BR> 9 Array.prototype.any=function(f){ <BR>10 for(var i=0;i<this.length;i++) if (f(this[i],i,this)) return true; <BR>11 return false <BR>12 }; <BR>13 <BR>14 <BR>15 <BR>16 //判断 字符串 是否符合 yyyy-mm-dd hh:mm:ss的日期格式, 格式正确而且闰年闰月等也要正确 <BR>17 <BR>18 String.prototype.isDateTime=function(){ <BR>19 try{ <BR>20 var arr=(this.length==19)?this.split(/\D/):[] <BR>21 --arr[1] <BR>22 eval("var d=new Date("+arr.join(",")+")") <BR>23 return Number(arr[0])==d.getFullYear() && Number(arr[1])==d.getMonth() <BR>24 && Number(arr[2])==d.getDate() && Number(arr[3])==d.getHours() <BR>25 && Number(arr[4])==d.getMinutes() && Number(arr[5])==d.getSeconds() <BR>26 }catch(x){return false} <BR>27 } <BR>28 <BR>29 /* <BR>30 alert("2002-12-12 10:10:40".isDateTime()) //true <BR>31 alert("2002-02-31 10:10:40".isDateTime()) //false <BR>32 alert("2002-22-31 10:10:40".isDateTime()) //false <BR>33 alert("2002-22-31 30:10:40".isDateTime()) //false <BR>34 */ <BR>35 <BR>36 <BR>37 // 检查 是否以特定的字符串结束 <BR>38 String.prototype.startsWith=function(){ <BR>39 var _string=this <BR>40 return $A(arguments).any(function(value){return _string.slice(0,value.length)==value}) <BR>41 }; <BR>42 /* <BR>43 alert("http://www.google.com/".startsWith("http://","ftp://","telnet://")) //true 满足其中任何一个就返回 true <BR>44 alert("http://www.google.com/".startsWith("https://","file://")) //false <BR>45 alert("abc".startsWith("a")) //true <BR>46 */ <BR>47 <BR>48 <BR>49 // 检查 是否以特定的字符串结束 <BR>50 String.prototype.endsWith=function(){ <BR>51 var _string=this <BR>52 return $A(arguments).any(function(value){return _string.slice(value.length*(-1))==value}) <BR>53 }; <BR>54 <BR>55 <BR>56 <BR>57 //从左边截取n个字符 ,如果包含汉字,则汉字按两个字符计算 <BR>58 String.prototype.left=function(n){ <BR>59 return this.slice(0,n-this.slice(0,n).replace(/[\x00-\xff]/g,"").length) <BR>60 }; <BR>61 /* <BR>62 alert("abcdefg".left(3)==="abc") <BR>63 alert("中国人cdefg".left(5)==="中国") <BR>64 alert("中国abcdefg".left(5)==="中国a") <BR>65 */ <BR>66 <BR>67 <BR>68 <BR>69 <BR>70 //从右边截取n个字符 ,如果包含汉字,则汉字按两个字符计算 <BR>71 String.prototype.right=function(n){ <BR>72 return this.slice(this.slice(-n).replace(/[\x00-\xff]/g,"").length-n) <BR>73 }; <BR>74 <BR>75 /* <BR>76 alert("abcdefg".right(3)==="efg") <BR>77 alert("cdefg中国人".right(5)==="国人") <BR>78 alert("abcdefg中国".right(5)==="g中国") <BR>79 */ <BR>80 <BR>81 </script>

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

楽なWebページレイアウトのためにjQueryを活用する:8本質的なプラグイン jQueryは、Webページのレイアウトを大幅に簡素化します。 この記事では、プロセスを合理化する8つの強力なjQueryプラグイン、特に手動のウェブサイトの作成に役立ちます

それで、あなたはここで、Ajaxと呼ばれるこのことについてすべてを学ぶ準備ができています。しかし、それは正確には何ですか? Ajaxという用語は、動的でインタラクティブなWebコンテンツを作成するために使用されるテクノロジーのゆるいグループ化を指します。 Ajaxという用語は、もともとJesse Jによって造られました

この投稿は、Android、BlackBerry、およびiPhoneアプリ開発用の有用なチートシート、リファレンスガイド、クイックレシピ、コードスニペットをコンパイルします。 開発者がいないべきではありません! タッチジェスチャーリファレンスガイド(PDF) Desigの貴重なリソース

jQueryは素晴らしいJavaScriptフレームワークです。ただし、他のライブラリと同様に、何が起こっているのかを発見するためにフードの下に入る必要がある場合があります。おそらく、バグをトレースしているか、jQueryが特定のUIをどのように達成するかに興味があるからです

10の楽しいjQueryゲームプラグインして、あなたのウェブサイトをより魅力的にし、ユーザーの粘着性を高めます! Flashは依然としてカジュアルなWebゲームを開発するのに最適なソフトウェアですが、jQueryは驚くべき効果を生み出すこともできます。また、純粋なアクションフラッシュゲームに匹敵するものではありませんが、場合によってはブラウザで予期せぬ楽しみもできます。 jquery tic toeゲーム ゲームプログラミングの「Hello World」には、JQueryバージョンがあります。 ソースコード jQueryクレイジーワードコンポジションゲーム これは空白のゲームであり、単語の文脈を知らないために奇妙な結果を生み出すことができます。 ソースコード jquery鉱山の掃引ゲーム

記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

このチュートリアルでは、jQueryを使用して魅惑的な視差の背景効果を作成する方法を示しています。 見事な視覚的な深さを作成するレイヤー画像を備えたヘッダーバナーを構築します。 更新されたプラグインは、jQuery 1.6.4以降で動作します。 ダウンロードしてください
