JS实用插件

1. jQuery鼠标滚轮事件插件Mouse Wheel

  下载链接:https://github.com/brandonaaron/jquery-mousewheel/

  使用方法:

// using bind
$(‘#my_elem‘).bind(‘mousewheel‘, function(event, delta) {
console.log(delta);
});

// using the event helper
$(‘#my_elem‘).mousewheel(function(event, delta) {
console.log(delta);
});

  要注意的是回调函数的第二个参数delta,它响应滚轮的方向,当为负数时表示向下滚动,为正则表示向上滚动。

2. javascript路由插件

  Crossroads.js, Director.js或是Sammy.js

  推荐Crossroads.js  使用详情google或百度

3. 复制到剪切板插件 zeroclipboard   

  下载地址:http://zeroclipboard.org/

  使用方法: 

<div id="click" data-clipboard-text="111111111111">点我复制</div>
if($.browser.msie){
     $("#click").click(function(){
                var text = $("#click").attr("data-clipboard-text");
                clipboardData.setData("Text",text);
      });
}else{
    window.client = new ZeroClipboard( $("#query_sql_click"));
}

4. jQuery 实现标点内容自动保存插件sisyphus.js

  下载地址:http://sisyphus-js.herokuapp.com/

  实用方法:$(‘form‘).sisyphus(); 

  设置选项,用户可随意进行设置:

  customKeyPrefix:自定义本地存储文件头

  timeout:间隔多长时间对数据进行自动保存。如果设置为0,那么所以字段更改都将被自动保存

  onSave:每次数据自动保存到本地存储将触发的函数。

  onRestore:如果数据从本地存储被恢复,触发的函数。

  onBeforeRestore:数据从本地存储恢复之前被触发。  该函数只触发一次

  onRelease:本地存储清空之前将触发该函数。

  autoRelease:设置本地自动保存的表单数据是否在表单提交或者重置的时候自动清空。 如果设置为false,为自己手动擦除本地存储的数据,插件专门提供了    manuallyReleaseData方法进行擦除。

  excludeFields:从选定的表单中排除指定的字段。如$( "textarea, :text" )

  name:表单的识别部分。sisyphus本地存储表单文件的名称。默认情况下为当前页面URL地址,是一个确定值。如果一个页面有多个地址,为了获取一致的数据,请设置一个唯一的name值。

  例如:下面的代码将对当前页面所有表单每5秒自动进行数据保存:

  $(‘form‘).sisyphus({timeout: 5});

5. placeholder插件

  百度很多这个插件有的ie不管用下面这个是ie有用的

/*! http://mths.be/placeholder v2.0.8 by @mathias */
;(function(window, document, $) {

    // Opera Mini v7 doesn’t support placeholder although its DOM seems to indicate so
    var isOperaMini = Object.prototype.toString.call(window.operamini) == ‘[object OperaMini]‘;
    var isInputSupported = ‘placeholder‘ in document.createElement(‘input‘) && !isOperaMini;
    var isTextareaSupported = ‘placeholder‘ in document.createElement(‘textarea‘) && !isOperaMini;
    var prototype = $.fn;
    var valHooks = $.valHooks;
    var propHooks = $.propHooks;
    var hooks;
    var placeholder;

    if (isInputSupported && isTextareaSupported) {

        placeholder = prototype.placeholder = function() {
            return this;
        };

        placeholder.input = placeholder.textarea = true;

    } else {

        placeholder = prototype.placeholder = function() {
            var $this = this;
            $this
                .filter((isInputSupported ? ‘textarea‘ : ‘:input‘) + ‘[placeholder]‘)
                .not(‘.placeholder‘)
                .bind({
                    ‘focus.placeholder‘: clearPlaceholder,
                    ‘blur.placeholder‘: setPlaceholder
                })
                .data(‘placeholder-enabled‘, true)
                .trigger(‘blur.placeholder‘);
            return $this;
        };

        placeholder.input = isInputSupported;
        placeholder.textarea = isTextareaSupported;

        hooks = {
            ‘get‘: function(element) {
                var $element = $(element);

                var $passwordInput = $element.data(‘placeholder-password‘);
                if ($passwordInput) {
                    return $passwordInput[0].value;
                }

                return $element.data(‘placeholder-enabled‘) && $element.hasClass(‘placeholder‘) ? ‘‘ : element.value;
            },
            ‘set‘: function(element, value) {
                var $element = $(element);

                var $passwordInput = $element.data(‘placeholder-password‘);
                if ($passwordInput) {
                    return $passwordInput[0].value = value;
                }

                if (!$element.data(‘placeholder-enabled‘)) {
                    return element.value = value;
                }
                if (value == ‘‘) {
                    element.value = value;
                    // Issue #56: Setting the placeholder causes problems if the element continues to have focus.
                    if (element != safeActiveElement()) {
                        // We can‘t use `triggerHandler` here because of dummy text/password inputs :(
                        setPlaceholder.call(element);
                    }
                } else if ($element.hasClass(‘placeholder‘)) {
                    clearPlaceholder.call(element, true, value) || (element.value = value);
                } else {
                    element.value = value;
                }
                // `set` can not return `undefined`; see http://jsapi.info/jquery/1.7.1/val#L2363
                return $element;
            }
        };

        if (!isInputSupported) {
            valHooks.input = hooks;
            propHooks.value = hooks;
        }
        if (!isTextareaSupported) {
            valHooks.textarea = hooks;
            propHooks.value = hooks;
        }

        $(function() {
            // Look for forms
            $(document).delegate(‘form‘, ‘submit.placeholder‘, function() {
                // Clear the placeholder values so they don‘t get submitted
                var $inputs = $(‘.placeholder‘, this).each(clearPlaceholder);
                setTimeout(function() {
                    $inputs.each(setPlaceholder);
                }, 10);
            });
        });

        // Clear placeholder values upon page reload
        $(window).bind(‘beforeunload.placeholder‘, function() {
            $(‘.placeholder‘).each(function() {
                this.value = ‘‘;
            });
        });

    }

    function args(elem) {
        // Return an object of element attributes
        var newAttrs = {};
        var rinlinejQuery = /^jQuery\d+$/;
        $.each(elem.attributes, function(i, attr) {
            if (attr.specified && !rinlinejQuery.test(attr.name)) {
                newAttrs[attr.name] = attr.value;
            }
        });
        return newAttrs;
    }

    function clearPlaceholder(event, value) {
        var input = this;
        var $input = $(input);
        if (input.value == $input.attr(‘placeholder‘) && $input.hasClass(‘placeholder‘)) {
            if ($input.data(‘placeholder-password‘)) {
                $input = $input.hide().next().show().attr(‘id‘, $input.removeAttr(‘id‘).data(‘placeholder-id‘));
                // If `clearPlaceholder` was called from `$.valHooks.input.set`
                if (event === true) {
                    return $input[0].value = value;
                }
                $input.focus();
            } else {
                input.value = ‘‘;
                $input.removeClass(‘placeholder‘);
                input == safeActiveElement() && input.select();
            }
        }
    }

    function setPlaceholder() {
        var $replacement;
        var input = this;
        var $input = $(input);
        var id = this.id;
        if (input.value == ‘‘) {
            if (input.type == ‘password‘) {
                if (!$input.data(‘placeholder-textinput‘)) {
                    try {
                        $replacement = $input.clone().attr({ ‘type‘: ‘text‘ });
                    } catch(e) {
                        $replacement = $(‘<input>‘).attr($.extend(args(this), { ‘type‘: ‘text‘ }));
                    }
                    $replacement
                        .removeAttr(‘name‘)
                        .data({
                            ‘placeholder-password‘: $input,
                            ‘placeholder-id‘: id
                        })
                        .bind(‘focus.placeholder‘, clearPlaceholder);
                    $input
                        .data({
                            ‘placeholder-textinput‘: $replacement,
                            ‘placeholder-id‘: id
                        })
                        .before($replacement);
                }
                $input = $input.removeAttr(‘id‘).hide().prev().attr(‘id‘, id).show();
                // Note: `$input[0] != input` now!
            }
            $input.addClass(‘placeholder‘);
            $input[0].value = $input.attr(‘placeholder‘);
        } else {
            $input.removeClass(‘placeholder‘);
        }
    }

    function safeActiveElement() {
        // Avoid IE9 `document.activeElement` of death
        // https://github.com/mathiasbynens/jquery-placeholder/pull/99
        try {
            return document.activeElement;
        } catch (exception) {}
    }

}(this, document, jQuery));

placeholder.js

  使用方法:

  添加css样式:   .placeholder { color: #aaa; }

  js代码:  $(‘input, textarea‘).placeholder();

 6. js获取系统时间 

  代码:

/**
 * get current time form the servers
 * @example
 * var time=new sysDate()
 * time.done(function(timeStamp){
 * console.log(timeStamp);
 * })
 */
(function(root, factory) {
    ‘use strict‘;
    var sysDate = function() {
        return sysDate.init.apply(sysDate, arguments);
    };
    factory(sysDate);
    if (typeof define === ‘function‘ && (define.amd || define.cmd)) {
        define(function( /*require, exports*/ ) {
            return sysDate;
        });
    } else {
        root.sysDate = sysDate;
    }
})(this, function(exp) {
    ‘use strict‘;
    exp.config = {
        url: ‘/‘
    };
    exp.init = function() {
        //the first arouments can be:
        //{url:‘/xxx‘}
        var arg = arguments[0];
        if (typeof(arg) == ‘object‘) {
            for (var i in arg) {
                exp.config[i] = arg[i];
            }
        }
        exp.get();
        return exp;
    };
    exp.get = function() {
        //use xmlhttp to get data form the server
        //save to config.lastDate
        var xmlhttp;
        if (window.XMLHttpRequest) {
            xmlhttp = new XMLHttpRequest();
        } else {
            xmlhttp = new ActiveXObject(‘Microsoft.XMLHTTP‘);
        }
        xmlhttp.onreadystatechange = function() {
            if (xmlhttp.readyState == 4) {
                var sysD = xmlhttp.getResponseHeader(‘Date‘);
                sysD = new Date(sysD);
                sysD = Date.parse(sysD);
                if (exp.doneFn) {
                    exp.doneFn(sysD);
                }
                exp.config.lastDate = sysD;
            }
        };
        exp.done = function(fn) {
            if (exp.config.lastDate) {
                if (fn) fn(exp.config.lastDate);
            } else {
                exp.doneFn = fn;
            }
        };
        xmlhttp.open(‘GET‘, exp.config.url, true);
        xmlhttp.send();
    };
});

sysDate

  使用方法:

var a=sysDate(option); // 可选字段option, {‘url‘:‘/getDate‘} a.done(function(data){ console.log(‘done‘,data); // 服务器时间 data 1385003673000‘ });

  详细介绍请看:http://www.zhuwenlong.com/blog/53a9475819a5a13617000001

 7. 实现网页截屏html2canvas

  下载地址:https://github.com/niklasvh/html2canvas

  使用方法:

<script type="text/javascript">
    function howuse(){
      html2canvas(document.getElementById(‘email_content‘), {
         onrendered: function(canvas){
            var html_canvas = canvas.toDataURL();
            $.post(‘/report/send_rep_submit‘, {html_canvas:html_canvas}, function(json){
                }, ‘json‘);
            }
        });
    }
  </script>

  可以这样查看图片:利用canvas.toDataURL();得到的是base64图片数据

<img src=“%3D%3D”/>

  

JS实用插件

时间: 2024-08-30 12:05:07

JS实用插件的相关文章

纯js实用DOM元素放大缩小特效插件

Zoomerang.js是一款非常实用的HTML DOM元素放大缩小js特效插件.它可以将页面上的任何元素进行放大缩小.当某个元素处于Zoomerang的监听状态时,点击该元素可以将它放大到屏幕的中间,再次点击它又会回到原来的位置. 使用注意事项: 该元素放大缩小效果依赖于CSS Transform(IE浏览器至少要IE10才能支持) 在固定尺寸的元素上效果最佳:display: block.display: inline-block和img. 避免在很长的文本段上使用. 在mobile上使用时

js日期插件

推荐一款贤心写的js日期插件,调用非常方便:顺手写了一个demo. 先列举下这款插件的优点:日期范围限制.开始日期设定.自定义日期格式.时间戳转换.当天的前后若干天返回.时分秒选择.智能响应.自动纠错.节日识别.快捷键操作.更换皮肤等. 当然还有很重要的一点是使用简单: 代码如下: <!DOCTYPE html> <html> <head>     <meta charset="UTF-8">     <title>data_

JS小插件之2——cycle元素轮播

元素轮播效果是页面中经常会使用的一种效果.这个例子实现了通过元素的隐藏和显示来表现轮播效果.效果比较简单. 效果图如下: 源代码如下: 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" Content="text/html; charset=utf-8;"> 5 <title> cycle demo </titl

根据一篇js日历插件改写的

1 <!-- 2 控件调用示例: 3 --> 4 5 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 6 7 <html xmlns="http://www.w3.org/1999/xhtml"> 8 9 <he

Sublime Text 3 JS 格式化插件 JsFormat的配置使用

1.首先需要下载安装包:(下载地址:https://github.com/jdc0589/JsFormat) 2.插件包放到sublime安装目录的Data\Packages目录中 3.重新打开sublime就能使用js格式化插件 使用方法: 1.快捷键:ctrl+alt+f 2.先用快捷键打开命令面板 "ctrl + shift + p", 再输入 "Format: Javascript" 就可以使用格式化命令

Django 的css和js压缩插件:django_compressor

今天尝试了django_conpressor,一个在django框架中压缩css和js的插件,灰常有用 我把它加载在我的base的HTML template中,原来未经压缩的css和js是: <link rel="stylesheet" href = "include/style.css" type="text/css"> <link rel="stylesheet" href = "include

node.js实用小模块

1.浮点数操作 npm install float 2.MD5加密类 npm install MD5 3.xml解析类 1 npm install elementtree 4.转换字符串大小写 1 npm install convert_str 5.SoapClient 1 npm install soap 6.字符串操作类 1 npm install string 7.缓存 1 npm install memory-cache 8.jsontoxml;  objecttoxml 1 npm i

Eclipse的实用插件

Decompiler PyDev ShellEd AnyEdit PropertiesEditor System and Desktop Search 前三款可直接从Eclipse Marketplace搜索下载,第四个插件可点击下载,其它实用插件等工作中用到了再来贴上! 参考 https://dzone.com/articles/5-best-eclipse-plugins-2 https://mcuoneclipse.com/2012/04/06/5-best-eclipse-plugins

前端实用插件-输入

layDate    一款致力于成为全球最高大上的js日期插件. http://sentsin.com/layui/laydate/ ? bootstrap-datetimepicker    Bootstrap日期和时间表单组件 http://www.bootcss.com/p/bootstrap-datetimepicker/