浏览模式: 标准 | 列表分类:Javascript
Submitted by gouki on 2016, February 25, 2:31 PM
本来以为不能转,因为原作者在文章头部写:未经许可不得转载,但又在文末留下了,转载请保留地址。因此,先保留地址转载,再申请一下授权,原文地址是: http://blog.csdn.net/cuixiping/article/details/45932793
之所以转这个,是因为最近在处理上传的时候遇到了问题,原来xhr可以直接将file对象提交,如果用fileReader,出来的其实是base64的string,这时候怎么办是个问题。
好了不说废话,上内容。。。。
canvas转换为dataURL (从canvas获取dataURL)
XML/HTML代码
- var dataurl = canvas.toDataURL('image/png');
- var dataurl2 = canvas.toDataURL('image/jpeg', 0.8);
File对象转换为dataURL、Blob对象转换为dataURL
File对象也是一个Blob对象,二者的处理相同。
XML/HTML代码
- function readBlobAsDataURL(blob, callback) {
- var a = new FileReader();
- a.onload = function(e) {callback(e.target.result);};
- a.readAsDataURL(blob);
- }
- //example:
- readBlobAsDataURL(blob, function (dataurl){
- console.log(dataurl);
- });
- readBlobAsDataURL(file, function (dataurl){
- console.log(dataurl);
- });
dataURL转换为Blob对象
XML/HTML代码
- function dataURLtoBlob(dataurl) {
- var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
- bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
- while(n--){
- u8arr[n] = bstr.charCodeAt(n);
- }
- return new Blob([u8arr], {type:mime});
- }
- //test:
- var blob = dataURLtoBlob('data:text/plain;base64,YWFhYWFhYQ==');
dataURL图片数据绘制到canvas
先构造Image对象,src为dataURL,图片onload之后绘制到canvas
XML/HTML代码
- var img = new Image();
- img.onload = function(){
- canvas.drawImage(img);
- };
- img.src = dataurl;
File,Blob的图片文件数据绘制到canvas
还是先转换成一个url,然后构造Image对象,src为dataURL,图片onload之后绘制到canvas
利用上面的 readBlobAsDataURL 函数,由File,Blob对象得到dataURL格式的url,再参考 dataURL图片数据绘制到canvas
XML/HTML代码
- readBlobAsDataURL(file, function (dataurl){
- var img = new Image();
- img.onload = function(){
- canvas.drawImage(img);
- };
- img.src = dataurl;
- });
不同的方法用于构造不同类型的url (分别是 dataURL, objectURL(blobURL), filesystemURL)。这里不一一介绍,仅以dataURL为例。
filesystemURL不是指本地文件URL的形式(file:///….), 而是格式类似于 filesystem:http://... 的一种URL,支持沙盒文件系统的浏览器支持(目前仅Chrome)支持。
Canvas转换为Blob对象并使用Ajax发送
转换为Blob对象后,可以使用Ajax上传图像文件。
先从canvas获取dataurl, 再将dataurl转换为Blob对象
XML/HTML代码
- var dataurl = canvas.toDataURL('image/png');
- var blob = dataURLtoBlob(dataurl);
- //使用ajax发送
- var fd = new FormData();
- fd.append("image", blob, "image.png");
- var xhr = new XMLHttpRequest();
- xhr.open('POST', '/server', true);
- xhr.send(fd);
EOF--
整个世界清静 了
Javascript | 评论:0
| 阅读:24930
Submitted by gouki on 2015, July 29, 1:36 PM
其实在fullcalendar2中已经有现成的代码了,但是因为我用的是1,所以借鉴网上的一些代码加了自己的处理。可能写的比较恶心!
JavaScript代码
- function isOverlapping(event){
- var array=calendar.fullCalendar('clientEvents');
- var start=Date.parse(event.start);
- if(event.end==null){
- var end=start+defaultEventMinutes*60*1000;
- }else{
- var end=Date.parse(event.end);
- }
- for(i in array){
- if(array[i]._id!=event._id){
- var currentStart=Date.parse(array[i].start);
- if(array[i].end==null){
- var currentEnd=currentStart+defaultEventMinutes*60*1000;
- }else{
- var currentEnd=Date.parse(array[i].end);
- }
-
-
-
-
- console.log("start :"+start);
- console.log("current start :"+currentStart);
- console.log("end :"+end);
- console.log("current End :"+currentEnd);
- if(start>currentStart&&start<currentEnd){
- console.log('开始时间在其他日程之间');
- return true;
- }
- if(end>currentStart&&end<currentEnd){
- console.log('结束时间在其他日程之间');
- return true;
- }
- if(start==currentStart||end==currentEnd){
- console.log('//开始时间或者结束时间等于别人的时间');
- return true;
- }
- if(start<currentStart&&end>currentStart){
- console.log('其他日程在当前的日期中间');
- return true;
- }
- }
- }
- return false;
- }
其中:
defaultEventMinutes 默认应该是等于fullcalendar中的120的,但由于不是每个人都将默认日程设置为120分钟,所以加了个变量自定义一下。
只要不是120,还需要设置一下:fullcalendar({defaultEventMinutes:defaultEventMinutes});
在使用的时候,有3个事件需要用到它,eventDrop,eventResize,drop。drop是指将外部的日程(或者颜色)拖放到日历上。eventDrop,eventResize都是针对指定日程的。
JavaScript代码
-
- if(isOverLapping(event)){
- alert('日程安排有冲突');
- revertFunc();
- return ;
- }
至此,处理日程安排重复算是搞定。折腾了一天,网上的那个是直接比较对象。不能用==,好尴尬,所以就采用时间戳了
Javascript | 评论:0
| 阅读:23710
Submitted by gouki on 2013, October 29, 11:57 PM
Javascript的一个组件zepto恐怕现在很多人都在用了。毕竟它几乎完全兼容jquery的语法。而且压缩后只有9K。所以大部分人在做移动端的时候就开始选择了zepto。它足够轻量。
毕竟你想一个jquery几十K,再加上一个jquery-mobile。得。。。等死吧。啥也没做200K没了。
但它毕竟和jquery不太一样。有点小坑
1、jquery的$('aaa :eq') ,这种伪类的选择符。它不支持。但可以用$('xxx').eq()这种函数式来代替
2、新版默认不支持touch事件了。这点要注意
不过大部分情况下,都够你使用了:http://zeptojs.com/
Javascript | 评论:0
| 阅读:22046
Submitted by gouki on 2013, August 18, 9:50 PM
dwz其实在几年前就用过。但最近在做一个后台,于是又准备重操起来
在使用dwz的dialog的时候,我想利用它做一个登录框,但明显我不可能,也不允许用户关闭这个dialog,但dwz默认的dialog都是有一个最大化和关闭的。最多只是close可以传递一个能够return boolean的function。。。。
虽然我在加dwz作者QQ的时候,他说加一个display:none的CSS属性就可以了,但说老实话,我又不可能加全局的。我能干嘛?针对这个ID?在创建的时候指定固定的ID?然后加CSS?或许这是一个办法,但我后来是曲线救国了
1、创建的时候,close为一个function,调用param中的值。alert一个message,然后return false
2、在表单提交 的时候,如果为false,那当然没关系 。如果是为true,怎么关闭窗口呢?
因为我设置了close为function弹出一个提示,那么就算有提示,也还是会弹个窗。所以在这里我曲线救国
在最后closeCurren()的时候,我先设置data('close',''),借此屏蔽close的方式。(当然只能在返回正确的时候才可以这么做。不然,这个关闭的提示就被取消了)
至此曲线救国完成
Tags: dwz, jui
Javascript | 评论:0
| 阅读:17691
Submitted by gouki on 2013, July 16, 6:47 PM
Html中的comment其实也有nodeType的,只是我们一直不用罢了。它的nodeType = 8哦。于是,就有了一个基于jQuery的插件:comments
它来自:http://www.bennadel.com/blog/1563-jQuery-Comments-Plug-in-To-Access-HTML-Comments-For-DOM-Templating.htm
JavaScript代码
- <--- --------------------------------------------------------------------------------------- ----
-
- Blog Entry:
- jQuery Comments() Plug-in To Access HTML Comments For DOM Templating
-
- Author:
- Ben Nadel / Kinky Solutions
-
- Link:
- http:
-
- Date Posted:
- Apr 14, 2009 at 7:01 PM
-
- ---- --------------------------------------------------------------------------------------- --->
-
-
-
-
-
-
-
-
- jQuery.fn.comments = function( blnDeep ){
- var blnDeep = (blnDeep || false);
- var jComments = $( [] );
-
-
-
- this.each(
- function( intI, objNode ){
- var objChildNode = objNode.firstChild;
- var strParentID = $( this ).attr( "id" );
-
-
-
- while (objChildNode){
-
-
- if (objChildNode.nodeType === 8){
-
-
-
-
- jComments = jComments.add(
- "<div rel='" + strParentID + "'>" +
- objChildNode.nodeValue +
- "</div>"
- );
-
- } else if (
- blnDeep &&
- (objChildNode.nodeType === 1)
- ) {
-
-
- jComments = jComments.add(
- $( objChildNode ).comments( true )
- );
-
- }
-
-
- objChildNode = objChildNode.nextSibling;
-
- }
-
- }
- );
-
-
- return( jComments );
- }
代码其实并不多,大概知道就好,本来是用phpQuery也这样写的。但发现。。。stick的时候,即使我选择了nodeType=8也取不到值。我晕啊,最后我只能用正则将注释取出来当成内容用了。
早先有人把代码扔在textarea里,用来当成数据加载,现在也有人开始无耻的利用注释了。真不厚道
Tags: jquery, comment
Javascript | 评论:0
| 阅读:44908