定义日志输出函数

(function(){
if(window['console']){ return; }
window['console'] = {
log: function(){}
,clear: function(){}
,debug: function(){}
,error: function(){}
,info: function(){}
,count: function(){}
,time: function(){}
,trace: function(){}
,warn: function(){}
}
})();

定义全局的方法,实现加载cdn的响应的地址

(function(){
var url = 'Bad url, watch browser console error.',
Local = window.Local,
err = function(msg){ if(console && console.error){ console.error('[cdn function error] '+ msg + '.'); } },
cdn = function(path, type){
//path rule
if(path.charAt(0) != '/'){ err('@param path: relative to root start by /'); return url; }
//global block
if(!Local){ err('@see BETA-18932: template funciton {nova->globaJS}'); return url; }
var key = 'RELEASE_TAG', version = Local[key];
//version define
if(!version){ err('@see local: ' + key + ' not defined'); return url; }
//server define
key = type.toUpperCase() + 'SERVER', server = Local[key];
if(!server){ err('@see local: ' + key + ' not defined.'); return url; }
//bad server define
if(!server.match(/^(http|https)/)){ err('@see local: ' + key + ' is server, add protocol'); return url; }
if(server.match(/\/$/)){ err('@see local: ' + key + ' is server, not ending by \/'); return url; }
url = server+ '/' + version + path;
return url;
};
window.cdn_jsurl = function(path){ return cdn(path, 'js'); };
window.cdn_cssurl = function(path){ return cdn(path, 'css'); };
window.cdn_imgurl = function(path){ return cdn(path, 'img'); };
})();

全站监听连接事件

//监听全站的链接点击事件,检查是否存在data-from属性,并添加from参数至href属性中
(function(o){
if(!o) {return false;}
if(!o.Event) {return false;}
var checkFromDomain = function(href){
var domain = ["youku.com/v_show/","youku.com/show_page/","youku.com/u/U"];
for(var i=0,length=domain.length; i<length; i++){
if(href.indexOf(domain[i]) !== -1) {
return true;
}
}
}
o.nova_init_hook_data_from = function(){
o.Event.observe(document, "click", function(ev){
if(!ev) ev = o.event;
var target = ev.target || ev.srcElement;
if(!target) {return;}
if(target.tagName != 'A' && target.parentNode) {
target = target.parentNode;
}
if(target.tagName == 'A') {
var data_from = target.getAttribute("data-from");
var from = data_from || window.pvDataFrom;
var href = target.getAttribute("href");
if(from && from != '') {
if(href && href.indexOf('http') === 0 && href.indexOf('?from') === -1 && href.indexOf('&from') === -1 && checkFromDomain(href)) {
from = encodeURIComponent(from);
if(href.indexOf('?') !== -1){
target.setAttribute("href", href+'&from='+from);
}else{
target.setAttribute("href", href+'?from='+from);
}
}
}
}
});
}
})(window);

生成时间戳+6位随机数的字符串

var getPvid = function(len){
var randchar=["0","1","2","3","4","5","6","7","8","9",
"a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z",
"A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"
];
var i=0;
var r="";
var d=new Date();
for (i=0;i<len;i++){
var index=parseInt(Math.random()*Math.pow(10,6))%randchar.length;
r+=randchar[index];
}
return d.getTime()+r;
}

jsonp异步调用方法

	var jsonp = function(src, callback){
if(typeof(arguments[0]) != 'string'){ return; }
var callback = typeof(arguments[1]) == 'function' ? callback : function(){};
var head = document.getElementsByTagName('HEAD')[0];
var script = document.createElement('SCRIPT');
script.type = 'text/javascript';
script.src = src;
head.appendChild(script);
if(!/*@cc_on!@*/0) {
script.onload = function(){ callback(); this.parentNode.removeChild(this); }
}else{
script.onreadystatechange = function () {
if (this.readyState == 'loaded' || this.readyState == 'complete') {
callback();
this.parentNode.removeChild(this);
}
}
}
}

过滤空字符串

function ltrim(s){ return s.replace( /^(\s*| *)/, ""); }
function rtrim(s){ return s.replace( /(\s*| *)$/, ""); }
function trim(s){ return ltrim(rtrim(s));}

判断是否为空值

/**
* 判断变量是否空值
* undefined, null, '', false, 0, [], {} 均返回true,否则返回false
*/
function empty(v){
switch (typeof v){
case 'undefined' : return true;
case 'string' : if(trim(v).length == 0) return true; break;
case 'boolean' : if(!v) return true; break;
case 'number' : if(0 === v) return true; break;
case 'object' :
if(null === v) return true;
if(undefined !== v.length && v.length==0) return true;
for(var k in v){return false;} return true;
break;
}
return false;
}

根据cookie判断是否已经登录

var islogin = function(){
var username = '';
var ca = document.cookie.split(';');
for(var i=0;i < ca.length;i++) {
var c = ca[i];
while (c.charAt(0)==' ') c = c.substring(1,c.length);
if(c.indexOf('yktk=') == 0){
var u_info = decode64(decodeURIComponent(c).split("|")[3]);
if(u_info.indexOf(",") > -1 && u_info.indexOf("nn:") > -1 && u_info.indexOf("id:") > -1){
username = u_info.split(",")[1].split(":")[1];
if(username != '') break;
}
}
} return (username == '') ? false : true;
}

判断是否为email

function isEmail(mail){
return(new RegExp(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z]{1,4}$/).test(mail));
}

function U8_16(_1) {
    var i, len, c;
    var char2, char3;
    var ary = [];
    len = _1.length;
    i = 0;
    while (i < len) {
        c = _1.charCodeAt(i++);
        switch (c >> 4) {
        case 0:
        case 1:
        case 2:
        case 3:
        case 4:
        case 5:
        case 6:
        case 7:
            // 0xxxxxxx
            ary.push(_1.charAt(i - 1));
            break;
        case 12:
        case 13:
            // 110x xxxx   10xx xxxx
            char2 = _1.charCodeAt(i++);
            ary.push(String.fromCharCode(((c & 0x1F) << 6) | (char2 & 0x3F)));
            break;
        case 14:
            // 1110 xxxx 10xx xxxx 10xx xxxx
            char2 = _1.charCodeAt(i++);
            char3 = _1.charCodeAt(i++);
            ary.push(String.fromCharCode(((c & 0x0F) << 12) | ((char2 & 0x3F) << 6) | ((char3 & 0x3F) << 0)));
            break;
        }
    }
    return ary.join('');
}
function decode64(_1) {
    if(!_1) return '';
    var _2 = "ABCDEFGHIJKLMNOP"+"QRSTUVWXYZabcdef"+"ghijklmnopqrstuv"+"wxyz0123456789+/"+"=";
    var _3 = "";
    var _4, _5, _6;
    var _7, _8, _9, _a;
    var i = 0;
    _1 = _1.replace(/[^A-Za-z0-9\+\/\=]/g, "");
    do {
        _7 = _2.indexOf(_1.charAt(i++));
        _8 = _2.indexOf(_1.charAt(i++));
        _9 = _2.indexOf(_1.charAt(i++));
        _a = _2.indexOf(_1.charAt(i++));
        _4 = (_7 << 2) | (_8 >> 4);
        _5 = ((_8 & 15) << 4) | (_9 >> 2);
        _6 = ((_9 & 3) << 6) | _a;
        _3 = _3 + String.fromCharCode(_4);
        if (_9 != 64) {
            _3 = _3 + String.fromCharCode(_5);
        }
        if (_a != 64) {
            _3 = _3 + String.fromCharCode(_6);
        }
    } while (i < _1.length);
    return U8_16(_3);
}
function encode64(str)
{
    if(!str) return '';
    str = str.toString();
    var base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
    var base64DecodeChars = new Array(
       -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
       -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
       -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,
       52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1,
       -1, 0,   1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,
       15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
       -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
       41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1
    );
    var out, i, len;
    var c1, c2, c3;
    len = str.length;
    i = 0;
    out = "";
    while(i < len) {
        c1 = str.charCodeAt(i++) & 0xff;
        if(i == len)
        {
            out += base64EncodeChars.charAt(c1 >> 2);
            out += base64EncodeChars.charAt((c1 & 0x3) << 4);
            out += "==";
            break;
        }
        c2 = str.charCodeAt(i++);
        if(i == len)
        {
            out += base64EncodeChars.charAt(c1 >> 2);
            out += base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4));
            out += base64EncodeChars.charAt((c2 & 0xF) << 2);
            out += "=";
            break;
        }
        c3 = str.charCodeAt(i++);
        out += base64EncodeChars.charAt(c1 >> 2);
        out += base64EncodeChars.charAt(((c1 & 0x3)<< 4) | ((c2 & 0xF0) >> 4));
        out += base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >>6));
        out += base64EncodeChars.charAt(c3 & 0x3F);
    }
    return out;
}
function encodeUid(uid)
{
    if(!uid) return '';
    if(uid << 2 > 0){
        var enUid = 'U' + encode64(uid << 2);
    }else{
        //uid超过限制
        var enUid = 'U' + encode64(uid * 4);
    }
    return enUid;
}

youku的js脚本的工具函数和初始化方法的更多相关文章

  1. 【JS】403- JavaScript 工具函数大全(新)

    前言 一线大厂笔试题灵感来源 目录: 第一部分:数组 第二部分:函数 第三部分:字符串 第四部分:对象 第五部分:数字 第六部分:浏览器操作及其它 筛选自以下两篇文章: <127 Helpful ...

  2. JS开发常用工具函数 总结

    js原生工具库 1.isStatic:检测数据是不是除了symbol外的原始数据 */ function isStatic(value) { return( typeof value === 'str ...

  3. js常用的工具函数

    JS选取DOM元素的方法注意:原生JS选取DOM元素比使用jQuery类库选取要快很多1.通过ID选取元素document.getElementById('myid');2.通过CLASS选取元素do ...

  4. js 常用的工具函数

    1 类型判断 isString (o) { //是否字符串 return Object.prototype.toString.call(o).slice(8, -1) === 'String' } i ...

  5. JS开发常用工具函数

    1.isStatic:检测数据是不是除了symbol外的原始数据 function isStatic(value) { return ( typeof value === 'string' || ty ...

  6. 初始化加载和导航时脚本执行的函数(初始化脚本执行环境)page.evaluateOnNewDocument

    /** * Copyright 2017 Google Inc., PhantomJS Authors All rights reserved. * * Licensed under the Apac ...

  7. 【转】第6篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:自动注册JS脚本+自动反射方法分析

    作者: 牛A与牛C之间 时间: 2013-11-21 分类: 技术文章 | 暂无评论 | 编辑文章 主页 » 技术文章 » 第6篇:Xilium CefGlue 关于 CLR Object 与 JS ...

  8. IE11开发人员工具 js脚本debugger调试

    微软在浏览器IE11中对F12开发人员工具的UI进行了彻底的换脸,虽然有诸多的不习惯但也是有方便之处的,比如我们用到的最多的断点调试,在F12调试状态下会加载出页面的js脚本文件,而需要对某个文件中的 ...

  9. Dynamics CRM 365 不用按钮工具,直接用js脚本控制按钮的显示隐藏

    Dynamics CRM 365 不用按钮工具,直接用js脚本控制按钮的显示隐藏: try { // 转备案按钮 let transferSpecialRequestButton = parent.p ...

随机推荐

  1. URAL1036. Lucky Tickets

    链接 dp[i][j] += dp[i-1][j-g];背包吧 数据太大了 还是JAVA好用 import java.io.*; import java.math.*; import java.tex ...

  2. bzoj1821

    题目要求最近的两个部落间距尽可能最远 不难想到一种贪心的方法,对每两个点之间距离从小到大排序, 把每个点看成一个部落 然后不断将距离近的两个部落合并成一个部落,直到剩下了k个部落,那么下一条不同部落之 ...

  3. POJ 2253 Frogger(最小生成树)

    青蛙跳跃,题意大概是:青蛙从起点到终点进行一次或多次的跳跃,多次跳跃中肯定有最大的跳跃距离.求在所有的跳跃中,最小的最大跳跃距离SF-_-(不理解?看题目吧). 可以用最小生成树完成.以起点为根,生成 ...

  4. 深入理解c语言_从编译器的角度考虑问题_纪念Dennis Ritchie先生

    开源中国: Dennis Ritchie教授过世了,他发明了C语言,一个影响深远并彻底改变世界的计算机语言.一门经历40多年的到今天还长盛不训的语言,今天很多语言都受到C的影 响,C++,Java,C ...

  5. 《转》如何让你的网页加载时间降低到 1s 内

    当初分析了定宽高值和定宽高比这两种常见的图片延迟加载场景,也介绍了他们的应对方案,还做了一点技术选型的工作. 经过一段时间的项目实践,在先前方案的基础上又做了很多深入的优化工作.最终将好奇心日报的网页 ...

  6. Using the Task Parallel Library (TPL) for Events

    Using the Task Parallel Library (TPL) for Events The parallel tasks library was introduced with the ...

  7. HDU 5667 Sequence 矩阵快速幂

    官方题解: 观察递推式我们可以发现,所有的fi​​都是a的幂次,所以我们可以对f​i​​取一个以a为底的log,g​i​​=log​a​​ f​i​​ 那么递推式变g​i​​=b+c∗g​i−1​​+ ...

  8. Maximum Flow Exhaustion of Paths Algorithm

    参考youtube上的视频: http://www.youtube.com/watch?v=sxyCzzUuXLo 笔记: 只要是那条路上为0后,就不会再走那条路. 所以没有S->U->W ...

  9. bzoj 1226 [SDOI2009]学校食堂Dining(状压DP)

    Description 小F 的学校在城市的一个偏僻角落,所有学生都只好在学校吃饭.学校有一个食堂,虽然简陋,但食堂大厨总能做出让同学们满意的菜肴.当然,不同的人口味也不一定相同,但每个人的口味都可以 ...

  10. HW5.6

    import java.util.Scanner; public class Solution { public static void main(String[] args) { Scanner i ...