为你的评论表单添加一个画图板

在线体验:

Valine: https://flatblowfish.github.io/cave-draw

WordPress: https://blog.maplesugar.top/cave-draw

逻辑

一种插入到评论框中的是blob格式的图片,在提交的时候,转为base64格式的图片。

一种插入到评论框中的是base64格式的图片。base64格式的图片内容太长了,在图片上下添加其他评论内容比较麻烦。

评论测试,评论测试,评论测试,评论测试,评论测试,评论测试
<img id="cave-img" alt="画板图片,请勿删除" src="blob:https://blog.maplesugar.top/139ddd97-25ff-4aeb-9fee-cb1e57bea0ac" />
评论测试,评论测试,评论测试,评论测试,评论测试,评论测试
<img id="cave-img" alt="画板图片,请勿删除" src="....." />

使用方法

1. 引入js。

<script src="https://cdn.jsdelivr.net/gh/flatblowfish/cave-draw/dist/cave-draw.min.js"></script>

2.初始化配置。

new CaveDraw({
    // 评论表单的 textarea 元素, 画图板插入到它下面
    ele: '#comment',
    // 评论表单的 form 元素,用来在提交时生成 base64 格式的图片
    // 如果评论系统没有 form 元素,则不写或者留空。此时,
    // 相应的,会直接把 base64 格式的图片插入到评论表单的 textarea 元素
    formEle: '#commentform',
    // 指定特殊的评论系统,目前只弄了valine
    special: 'valine',
    // 画图板的打开按钮
    openBtn: {
        style: 'background-color:#b37ba4;color:white;',
        hoverStyle: 'background-color: #49d0c0;'
    },
    // 画图板的 canvas 元素
    canvasStyle: 'cursor:crosshair;background:whitesmoke;/*margin-bottom:5px;border-radius:0px;*/'
})

示例1-WordPress

1.functions.php中设置允许提交base64格式的图片。

/*
 * 评论框中,允许提交 <img id="" alt="" src="data:" /> 格式的图片
 * 注意需要设置允许 data 协议
*/
function add_allowed_html_tags() {
    global $allowedtags;
    $allowedtags['img'] = array(
        'src' => true,
        'alt' => true,
        'id' => true
    );
}
add_action('init', 'add_allowed_html_tags', 10);
add_filter('kses_allowed_protocols', function ($protocols) {
    $protocols[] = 'data';
    return $protocols;
});

2.配置CaveDraw。

new CaveDraw({
	ele: '#comment',
	formEle: '#commentform',
	openBtn: {
		style: 'background-color:#b37ba4;color:white;',
		hoverStyle: 'background-color: #49d0c0;'
	},
	canvasStyle: 'cursor:crosshair;background:whitesmoke;/*margin-bottom:5px;border-radius:0px;*/'
})

示例2-Valine

1.允许提交base64格式的图片。在Valine.min.js搜索allowedSchemes.some(,可以找到valine对于评论字段过滤的函数,在这个函数最开始添加if("data:image/"==e.substr(0,11))return true;

valine-modify文件夹中,已经有弄好的Valine.min.js,版本为1.4.18

function l(e) {
    if ("data:image/" == e.substr(0, 11)) return true;
    function t(t) {
    return 0 === e.indexOf(t + ":")
    }
    var n = e[0];
    if ("#" === n || "/" === n) return !0;
    var r = e.indexOf(":");
    if (-1 === r) return !0;
    var i = e.indexOf("?");
    if (-1 !== i && r > i) return !0;
    var o = e.indexOf("#");
    return -1 !== o && r > o || v.allowedSchemes.some(t)
}

2.配置CaveDraw,注意:由于对valine的submit按钮的click事件进行了拦截,所以,CaveDraw 初始化要在valine前面

<style>
    .brush-detail p {
        line-height: 1em!important;
    }
    .v[data-class="v"] .veditor {
        max-height: 17em;
    }
</style>
<script>
// 由于对valine的submit按钮的click事件进行了拦截,所以,CaveDraw 初始化要在valine前面
new CaveDraw({
	// 评论表单的 textarea 元素, 画图板插入到它下面
	ele: '#veditor',
	// 指定特殊的评论系统,目前只弄了valine
	special: 'valine',
	// 画图板的打开按钮
	openBtn: {
		style: 'background-color:#b37ba4;color:white;',
		hoverStyle: 'background-color: #49d0c0;'
	},
	// 画图板的 canvas 元素
	canvasStyle: 'cursor:crosshair;background:whitesmoke;/*margin-bottom:5px;border-radius:0px;*/'
})

var valine = new Valine();
valine.init({
	el: '.comment',
	app_id: '',
	app_key: '',
	placeholder: 'ヾノ≧∀≦)o来啊,快活啊!',
	path: window.location.pathname,
	avatar:'mm', // 1.1.7 新增(mm/identicon/monsterid/wavatar/retro)
	// guest_info: ['nick'] // 默认 ['nick', 'mail', 'link']
});
</script>

在本地打开test/valine/index.html,可以查看效果。

示例3-其他

没有form的表单,也没有被作者特殊照顾的评论系统,可以直接把base64格式图片插入。

<style>
    /* 设置评论框最大高度,因为base64格式图片太长 */
    #comment {
        max-height: 300px;
    }
</style>
<script>
new CaveDraw({
    // 评论表单的 textarea 元素, 画图板插入到它下面
    ele: '#comment',
    // 评论表单的 form 元素,用来在提交时生成 base64 格式的图片
    // 如果评论系统没有 form 元素,则不写或者留空。此时,
    // 相应的,会直接把 base64 格式的图片插入到评论表单的 textarea 元素
    // formEle: '#commentform',
    // 画图板的打开按钮
    openBtn: {
        style: 'background-color:#b37ba4;color:white;',
        hoverStyle: 'background-color: #49d0c0;'
    },
    // 画图板的 canvas 元素
    canvasStyle: 'cursor:crosshair;background:whitesmoke;/*margin-bottom:5px;border-radius:0px;*/'
})
</script>
Copyright © 2022,枫糖, 版权所有,禁止转载、演绎、商用。

打赏作者

离开前,建议您浏览一下 归档 页面,或许有更多相关的、有趣的内容!

5 个评论

  1. maplesugar 2022-01-24
  2. maplesugar 2022-01-24
  3. maplesugar 2022-01-25
  4. Heo 2022-03-15

添加评论

code