2021-05-07 22:31:19 +00:00
|
|
|
/**
|
2022-06-24 02:16:50 +00:00
|
|
|
* code
|
|
|
|
* 代码区简易修饰
|
2017-08-21 00:51:13 +00:00
|
|
|
*/
|
|
|
|
|
2022-06-24 02:16:50 +00:00
|
|
|
layui.define(['util'], function(exports){
|
2017-08-21 00:51:13 +00:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var $ = layui.$;
|
2022-06-24 02:16:50 +00:00
|
|
|
var util = layui.util;
|
2017-08-21 00:51:13 +00:00
|
|
|
|
|
|
|
exports('code', function(options){
|
|
|
|
var elems = [];
|
2022-06-24 02:16:50 +00:00
|
|
|
var trim = function(str){
|
|
|
|
return $.trim(str).replace(/^\n|\n$/, '');
|
|
|
|
}
|
|
|
|
|
2017-08-21 00:51:13 +00:00
|
|
|
options = options || {};
|
|
|
|
options.elem = $(options.elem||'.layui-code');
|
2021-03-31 06:07:23 +00:00
|
|
|
options.lang = 'lang' in options ? options.lang : 'code';
|
2017-08-21 00:51:13 +00:00
|
|
|
|
|
|
|
options.elem.each(function(){
|
|
|
|
elems.push(this);
|
|
|
|
});
|
|
|
|
|
|
|
|
layui.each(elems.reverse(), function(index, item){
|
2022-06-24 02:16:50 +00:00
|
|
|
var othis = $(item);
|
|
|
|
var html = trim(othis.html());
|
2022-06-29 00:22:26 +00:00
|
|
|
var about = othis.attr('lay-about') || options.about || (
|
|
|
|
othis.attr('lay-lang') || options.lang
|
|
|
|
) || '';
|
2017-08-21 00:51:13 +00:00
|
|
|
|
2022-06-24 02:16:50 +00:00
|
|
|
// 转义 HTML 标签
|
2017-08-21 00:51:13 +00:00
|
|
|
if(othis.attr('lay-encode') || options.encode){
|
2022-06-24 02:16:50 +00:00
|
|
|
html = util.escape(html);
|
2017-08-21 00:51:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
othis.html('<ol class="layui-code-ol"><li>' + html.replace(/[\r\t\n]+/g, '</li><li>') + '</li></ol>')
|
|
|
|
|
|
|
|
if(!othis.find('>.layui-code-h3')[0]){
|
2022-06-29 00:22:26 +00:00
|
|
|
othis.prepend('<h3 class="layui-code-h3">'+ (othis.attr('lay-title')||options.title||'</>') + '<a href="javascript:;">'+ about +'</a>' + '</h3>');
|
2017-08-21 00:51:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var ol = othis.find('>.layui-code-ol');
|
|
|
|
othis.addClass('layui-box layui-code-view');
|
|
|
|
|
|
|
|
//识别皮肤
|
|
|
|
if(othis.attr('lay-skin') || options.skin){
|
|
|
|
othis.addClass('layui-code-' +(othis.attr('lay-skin') || options.skin));
|
|
|
|
}
|
|
|
|
|
|
|
|
//按行数适配左边距
|
|
|
|
if((ol.find('li').length/100|0) > 0){
|
|
|
|
ol.css('margin-left', (ol.find('li').length/100|0) + 'px');
|
|
|
|
}
|
|
|
|
|
|
|
|
//设置最大高度
|
|
|
|
if(othis.attr('lay-height') || options.height){
|
|
|
|
ol.css('max-height', othis.attr('lay-height') || options.height);
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
2021-04-22 02:22:45 +00:00
|
|
|
}).addcss('modules/code.css?v=2', 'skincodecss');
|
2021-03-31 09:36:19 +00:00
|
|
|
|