2012年4月22日星期日

【转】javascript中字符串替换函数replace()方法详解

在javascript中,String的函数replace()简直太让人喜爱了。它灵活而强大的字符替换处理能力,让我不禁想向大家介绍它。

  replace()最简单的算是能力就是简单的字符替换。示例代码如下:

<script language="javascript">
var strM = "javascript is a good script language";
//在此我想将字母a替换成字母A
alert(strM.replace("a","A"));
</script>

  我想大家运行后可以看到结果,它只替换了首字母。但如果加上正则表达式结果就不一样了!呵呵,没错。replace()支持正则表达式,它可以按照正则表达式的规则匹配字符或字符串,然后给予替换!

<script language="javascript">
var strM = "javascript is a good script language";
//在此我想将字母a替换成字母A
alert(strM.replace(/a/,"A"));
</script>

  呵呵,您一定发现了。这样还是只替换了第一个字母a。如果您熟悉正则,那这就难不住您。稍加修改就OK了。

<script language="javascript">
var strM = "javascript is a good script language";
//在此将字母a全部替换成字母A
alert(strM.replace(/a/g,"A"));
</script>

  还可以这样,看看效果!

<script language="javascript">
var strM = "javascript is a good script language";
alert(strM.replace(/(javascript)\s*(is)/g,"$1 $2 fun. it $2"));
</script>

  我这儿举的例子都是很简单的应用,replace()在此点上与您使用正则表达式的能力成正比。您正则表达式越强,呵呵,那您就会越疯狂的爱上它。

  当然,我这儿推荐replace()的原因并不因为它能与正则表达式合作,而在于它还能与函数进行合作,发挥出强大的功能。

  先看看简单例子:将所有单词首字母换成大写。

<script language="javascript">
var strM = "javascript is a good script language";
function change(word)
{
 return word.indexOf(0).toUpperCase()+word.substring(1);
}
alert(strM.replace(/\b\w+\b/g,change));
</script>

  由上可知,当正则表达式有"g"标志时,代表将处理整个字符串,即函数change的变换将应用于所有匹配的对象。而该函数有三个或更多参数,具体个数视正则表达式而定。

  有了函数与正则表达式的配合,replace()处理字符串的功能空前强大起来了!

  最后还举个例子,将字符串所有单词倒序,用replace()处理是如此简单。

<script language="javascript">
var strM = "javascript is a good script language";
function change(word)
{
 var result = word.match(/(\w)/g);
if ( result )
{
 var str = "";
  for ( var i=result.length-1; i>=0; i-- )
 {
   str += result;
 }
 return str;
}
else
{
  return "null";
}
}
alert(strM.replace(/\b(\w)+\b/g,change));
</script>

摘自:http://www.busfly.net/post/160.html

2012年4月21日星期六

【转】文件上传组件(Flash,JQuery,asp,php,js,AJAX)

摘自:http://www.cnblogs.com/yuko/archive/2011/09/26/upfile.html

 FancyUpload 
FancyUpload是一个采用Flash与Ajax(MooTools)技术实现包含上传进度条的多文件上传组件,类似于SWFUpload。

FancyUpload

 Mootools  

 jqUploader 
结合Javascript与Flash开发,拥有上传进度条的文件上传控件。

jqUploader

 jQuery  

 Ext UploadForm 
Ext UploadForm扩展至Ext.form.BasicForm用于多文件上传。文件先被加到上传队列中然后再一起上传至服务器,Ext UploadForm还提供一个上传进度条用于显示上传的详细信息。

Ext UploadForm

 ExtJs  

 SwfUploadPanel 
SwfUploadPanel是一个结合SwfUpload v2.0.2与ExtJS 2.0.x开发的多文件上传面板(panel)。
SwfUploadPanel

SwfUploadPanel

 ExtJs Widgets  

 Yahoo! UI Library: Uploader 
YUI Uploader Control结合Flash开发的文件上传控件。支持在同一个"Open File"对话框中一次性选择多个文件。文件扩展名过滤,以帮助用户准确选择。文件上传过程跟踪。在文件上传POST请求中附件额外的参数。

Yahoo! UI Library: Uploader

 YUI  

 jQuery Multiple File Upload Plugin 
多文件上传插件(jQuery.MultiFile)能够让用户一次性选择多个要上传的文件。此外该插件还提供一些基本的校验功能比如:文件扩展名校验。

jQuery Multiple File Upload Plugin

 jQuery  

 dhtmlxVault 
基于Ajax技术开发,包含上传进度提醒的DHTML JavaScript文件上传控件。不同的文件类型会显示相应的icons。

dhtmlxVault

 

 jQuery: Ajax file upload 
Ajax文件上传插件让用户能够很方便地上传多个文件而无需刷新页面。此外,可以使用任何元素(图片,文字,按纽等)来触发文件选择窗口。

jQuery: Ajax file upload

 jQuery  

 uploadify 
uploadify这是一个基于Flash技术的文件上传jQuery插件。提供的功能包括:能够一次性选择多个文件上传,查看上传进度,控制文件上传类型和大小,为每一步操作添加回调函数等。该插件还自带一个PHP文件用于服务器端处理上传文件。

uploadify

 jQuery Php  

 jcUpload 
jcUpload 是一个采用Flash与jQuery实现的Ajax文件上传组件。支持文件上传进度条提示。支持多文件上传,用户可以在文件选择框按住Ctrl或 Shift键一次选择多个文件。支持自定义文件扩展名过滤,限制个别文件大小,控制待上传文件队列大小/数量。易于自定义外观。
jcUpload.jpg

jcUpload

 jQuery 

 JSUpload 
JSUpload是一个JavaScript文件上传控件,它提供一个进度条来显示实时上传信息包括:文件大小,已传输的字节数等。
gwtupload.jpg

JSUpload

 

 jQuery Image Cropper with Uploader 
包含上传功能的图片在线裁剪工具。此外该工具还提供旋转、颜色变换等功能。
crop1_11.jpg

jQuery Image Cropper with Uploader

 Image jQuery  

 Plupload 
Plupload 这个JavaScript控件可以让你选择Adobe Flash、Google Gears、HTML5、Microsoft Silverlight、Yahoo BrowserPlus或正常表单Form等多种方法进行文件上传。Plupload还提供其它功能包括:上传进度提醒、图片缩小、多文件上传,拖拽文件 到上传控件,文件类型过滤和Chunked上传等。这些功能在不同的上传方式中支持情况会受到限制。
file-upload-script.jpg

Plupload

 

 noSWFUpload 
noSWFUpload是一个Ajax多文件上传组件。不需要SWF,Applets或其它浏览器插件支持。
noSWFUpload.jpg

noSWFUpload

 

 SWFUpload 
SWFUpload 是一个基于flash与javascript的客户端文件上传组件。你可以在文件选择对话框中通过ctrl/shift键一次性选择多个上传文件。可以在 所有事件中加入Javascript回调函数。可以在上传开始前取得文件信息。能够利用HTML显示文件上传中的一些信息。不需要刷新页面。当不支持 Flash或javascript时,能够自动变成正常的HTML上传Form。可以在上传开始前控制文件大小。 当上传多个文件时,它将自动创建上传队列,在还没有开始上传前可从队列中移除或添加文件。
SWFUploa.jpg

SWFUpload

 

 Ajax Upload 
Ajax Upload是一个带有上传进度条并支持将文件从本地计算机拖到页面中进行上传的文件上传组件,但这两个功能只能在FF3.6+、Safari4+和 Chrome浏览器中使用。其它浏览器只是利用一个隐藏的iframe进行不刷新上传,不支持文件拖动和进度提醒。支持在FF、Chrome和 Safari浏览器中一次性选择多个文件上传,可以通过CSS更新外观,可以在上传过程中取消上传,没有用到Flash支持,兼容https。
AjaxUpload.jpg

Ajax Upload

 

 Agile Uploader 
Agile Uploader是一个文件上传控制,支持在上传之前利用Flash将图片缩小。支持上传单个和多个文件上传。由于上传按纽没有放在Flash文件中,所 以可以自己定义风格外观。此外还提供各种JS回调函数。Flash部分也有很多参数可以设置包括风格和图片缩小质量。
agile-uploader.gif

Agile Uploader

 

 RightJS 
RightJS 是一个非常小,模块化并依赖于插件和prototype扩展来增强功能的JavaScript框架与jQuery框架非常相似。同样拥有非常多的简短和便 利的方法,能够帮助你编写出简洁、紧凑的代码。它RightJS更加面向对象,专门为熟悉服务器动态语言(如:Ruby和Python)的开发人员而设 计。此外RightJS还提供了一些常用的WebUI包括:Autocompleter、Calendar、colorpicker、Lightbox、 Rater、Slider、Sortable、Tabs、Tooltips、Uploader等。
RightJS.jpg

RightJS

 AutoComplete Color DatePicker Framework Slider  

 jQuery File Upload Plugin 
jQuery File Upload Plugin允许你一次性选择多个文件并将它们同时上传。可以把要上传的文件从桌面或文件管理器中拖到浏览器窗口中进行上传。可以显示单个文件的上传进 度,上传过程中还可以取消来停止上传过程。它还提供API来设置单独的选项并为各种上传事件定义回调方法。
jquery-file-upload.jpg

jQuery File Upload Plugin

 jQuery