封装jquery高亮插件?

Posted duanzhange

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了封装jquery高亮插件?相关的知识,希望对你有一定的参考价值。

完整的高亮插件代码如下:

//闭包限定命名空间
(function ($) {
    $.fn.extend({
        "highLight": function (options) {
            //检测用户传进来的参数是否合法
            if (!isValid(options))
                return this;
            var opts = $.extend({}, defaluts, options); //使用jQuery.extend 覆盖插件默认参数
            return this.each(function () {  //这里的this 就是 jQuery对象。这里return 为了支持链式调用
                //遍历所有的要高亮的dom,当调用 highLight()插件的是一个集合的时候。
                var $this = $(this); //获取当前dom 的 jQuery对象,这里的this是当前循环的dom
                //根据参数来设置 dom的样式
                $this.css({
                    backgroundColor: opts.background,
                    color: opts.foreground
                });
                //格式化高亮文本
                var markup = $this.html();
                markup = $.fn.highLight.format(markup);
                $this.html(markup);
            });


        }
    });
    //默认参数
    var defaluts = {
        foreground: ‘red‘,
        background: ‘yellow‘
    };
    //公共的格式化 方法. 默认是加粗,用户可以通过覆盖该方法达到不同的格式化效果。
    $.fn.highLight.format = function (str) {
        return "<strong>" + str + "</strong>";
    }
    //私有方法,检测参数是否合法
    function isValid(options) {
        return !options || (options && typeof options === "object") ? true : false;
    }
})(window.jQuery);

 

 

 //调用
        //调用者覆盖 插件暴露的共公方法
        $.fn.highLight.format = function (txt) {
            return "<em>" + txt + "</em>"
        }
        $(function () {
            $("p").highLight({ foreground: ‘orange‘, background: ‘#ccc‘ }); //调用自定义 高亮插件
        });

 







































以上是关于封装jquery高亮插件?的主要内容,如果未能解决你的问题,请参考以下文章

有没有js、jquery插件或者flash插件,可以对图片进行多个区域的高亮显示(遮罩显示)?

Jquery 点击按钮自动高亮实现原理及代码

jquery日历,有日程的日期高亮有链接,鼠标经过显示具体日程浮框。

vscode必装插件

关键字搜索高亮jQuery插件

Vue中通过highlight.js实现代码高亮