QQ空间BGM的免费处理方式

众所周知TX的“特别”服务都是要(红黄蓝绿黑彩粉紫魔等)钻的,当然还有QQ会员。
这次在这里谈的是和QQ空间绿钻有关的BGM
大家([ke neng bu])知道,QQ空间有个叫背景音乐的东西,

这是添加音乐的三个方法,用复眼就可以看出来前两个是绿钻专用的,很明显普通用户只可以选第三个,但是我突然发现不管怎么样,我们都应该选第三个才是正确的,why?
因为一旦你绿钻到期或者不想再每月浪费10冥币,那么所谓的正版乐库和添加本地音乐都会翻脸不认人。
既然要选第三个,那就要有外链可以链接,这个可以去百度音乐等等地方找到,但是本文说的不是这么没含量的。
要自由上传音乐,就自己去找免费空间来外链吧骚年们,然后绑个域名。【为啥不用ip呢?因为这些免费空间不能保证永远都正常运作,假如用ip,一旦换了服务器就要换掉背景音乐里所有歌的链接,用域名只要更改域名的指向ip或dns服务就行了】
这就是所谓正版乐库和外链的区别

但是使用过程中没有任何区别,看起来好像所谓的连接率不怎么样,但是听是没有任何问题的。。。所以这是个很好的选择
进我的空间可以听效果【保护好猫耳】

我已经准备什么时候撤掉绿钻了,到时全部换成外链。
外链服务器至少要可以达到以下要求
稍微有点带宽
有很大的存储空间
有很多或者无限流量【不然浏览一多流量就没了】
文件大小最好不限制
不会有清除文件的行为[比如Free Web Hosting Area我一开始用的空间就一直会莫名其妙的删掉一些相对来说和网页无关的文件]
现在我用了一个tk域名绑定在外链空间上jiastorage.tk

自己创建外链服务器的好处是可以自由上传文件,也可以外链一些其他东西【虽说文件安全性不能保证】但是这比每月十元的钻划算多了

QQ邮箱的正确用法


先来一张图~!
一般人看到TX邮箱这个3月扩容功能都会觉得是坑爹【谁会用到这么多啊】
但是我发现用它来备份数据库爽爆了
使用wordpress插件WordPress Database Backup设定定时备份并发送到邮箱,于是这个奸诈的任务就开始运行了【发送时占用一定带宽,若不是托管的blog还是别用这功能了】

下面是进度

到现在为止只用了这些

文章越来越大了= =

自从用datauri来存放图片,我的文章数据表就变得越来越大了。。
这是纯文章的时候

然后这是用了datauri以后。。

这么做唯一的好处就是博客搬家的时候用不着再去搬上传的文件,缺点就是这个数据库不知什么时候就会有几个G出来。。然后我要怎么备份- –

[更新:博主已洗心革面,不再用datauri了。。]

图片转data:URI工具

昨晚由于需要用data:uri,于是做了这么个转换工具
可本地使用,因为文件不用上传
疯狂的点击这里看demo
截图[此截图使用datauri,看不见请升级人品]

上面这张图的datauri



datauri优点:
在页面添加图片不用额外上传文件了!
还有什么就不知到了
缺点:
无法缓存,每次加载页面都要载入(其实想缓存它只要用js文件复制给变量就行了,而且可以一个文件存N张图,和图片分割异曲同工啊)
浏览器支持不全面
转出来的字符串体积一般比原文件大= =。。。

demo源码[部分参考其他网站]

把图片拖到这里

[其实我发现除了图片以外还可以拖其它任何文件进来,只不过下面的预览图会裂掉另外最好不要把超过1MB的文件拉进来,不然你懂的]

PS:如果同时拖入多个文件,只操作第一个,拖入文件夹无效

视频手动载入js

俺花了好长时间,用我这不熟练的技术好不容易做了个带满缺点的js
那么这货的用处就是屏蔽掉flash这样的东西【当然如果修改一下js可以屏蔽掉body里的任何标签
先来个示例【有视频有真相
embed标签的例子(无视频源)video标签的例子(同上)

其实屏蔽了以后看起来都是一样的。。

这货的功能:点击以后再载入,防止意外流量损失或带宽?占用
这就是个鲜明的例子181
里面装满了视频,这样就可以解决打开这个网页一下载入很多视频的问题了

原理:让div插队再干掉背后的原标签并给这个div添加可以给自己内部写入被杀掉标签的事件↓

objarray[i].parentNode.insertBefore(tmpdiv,objarray[i]);//插队到原标签前面
objarray[i].parentNode.removeChild(objarray[i]);//干掉原标签

特点:插队的div使用源元素的宽高和定位【本来想把z-index也算进去的,时间不够就不做了↓

//一堆if用来判断是否有这些属性
if(getwidth(objarray[i])){tmpdiv.style.width=getwidth(objarray[i]);}
if(getheight(objarray[i])){tmpdiv.style.height=getheight(objarray[i]);}
if(getposition(objarray[i])){tmpdiv.style.position=getposition(objarray[i]);}
if(getright(objarray[i])){tmpdiv.style.right=getright(objarray[i]);}
if(getleft(objarray[i])){tmpdiv.style.left=getleft(objarray[i]);}

全代码↓

var changevideos=function(){
var target=new Object;
function findtag(tag) {
return document.getElementsByTagName(tag);
}
function getwidth(obj){
if(obj.width){return obj.width;}else if(obj.style.width){return obj.style.width;}else{return false;}
}
function getheight(obj){
if(obj.height){return obj.height;}else if(obj.style.height){return obj.style.height;}else{return false;}
}
function getposition(obj){
return obj.style.position?obj.style.position:false;
}
function getright(obj){
return obj.style.right?obj.style.right: false;
}
function getleft(obj){
return obj.style.left?obj.style.left:false;
}
function changeinner(html){
target=event.srcElement?event.srcElement:event.target;
target.innerHTML=html;
}
function run(objarray){
for (var i = 0; i < objarray.length; i++) { var aimhtml = objarray[i].outerHTML; var tmpdiv=document.createElement("div"); if(getwidth(objarray[i])){tmpdiv.style.width=getwidth(objarray[i]);} if(getheight(objarray[i])){tmpdiv.style.height=getheight(objarray[i]);} if(getposition(objarray[i])){tmpdiv.style.position=getposition(objarray[i]);} if(getright(objarray[i])){tmpdiv.style.right=getright(objarray[i]);} if(getleft(objarray[i])){tmpdiv.style.left=getleft(objarray[i]);} tmpdiv.innerHTML='<div class="hideitemzhanwei" style="width:'+getwidth(objarray[i])+'px;height:'+getheight(objarray[i])+'px;"><center><h2 style=\'color:#fff;\'>为了防止流量计费用户的流量损失<br>此处已被自动屏蔽</h2><span style="position:absolute;bottom:2px;right:2px;">点击恢复</span></center></div>';//填上填充显示的内容
//tmpdiv.style.overflow="hidden";
tmpdiv.setAttribute('onClick','changevideos.changeinner(\''+aimhtml+'\')');
tmpdiv.style.display="inline-block";
objarray[i].parentNode.insertBefore(tmpdiv,objarray[i]);
objarray[i].parentNode.removeChild(objarray[i]);
}
}
function changehideneededtag() {
var tmpstyle=document.createElement("style");
tmpstyle.innerHTML=".hideitemzhanwei{position:relative;background-color:#66ccff;color:#fff;cursor:pointer;}";
document.getElementsByTagName("head")[0].appendChild(tmpstyle);
var a;
if(a=findtag("embed")){
run(a);}
if(a=findtag("object")){
run(a);}
if(a=findtag("video")){
run(a);}
}
changehideneededtag();
}
changevideos.changeinner=function(html){
target=event.srcElement?event.srcElement:event.target;
target.innerHTML=html;
}

没时间了所以还有些可能出错的地方没做错误处理,以后来补上