flask - 如何在烧瓶中为 wysisyg 编辑器 insertImage 设置默认目录
问题描述
我正在烧瓶中构建一个 CMS,并且我已经使用 execcommands 构建了一个简单的所见即所得编辑器来创建和编辑帖子,并且一切正常。对于 insertImage 命令,我使用输入元素打开目录并选择图像。它可以工作,当然它会打开我的计算机默认文件夹。我希望它打开用户图像存储在烧瓶中的静态目录中的上传文件夹。如何?
我搜索了烧瓶文档、Python 处理文件文档,但没有提及这一点。这是我正在为一个班级做的一个项目。我正在超越这个项目的要求,但这就是我让事情变得有趣的方式。我的意思是它应该是一个CMS的权利。好吧,CMS 总是有所见即所得的,可以打开默认的“上传”文件夹来插入媒体。另外,在创建我的上传功能时,我发现上传文件时烧瓶需要绝对路径。但是在为他们服务时,相对路径是必要的。任何正确方向的观点都将不胜感激。谢谢你。
这是结构
<div class="col-md-1 tools">
<a href="#" data-command='insertImage'data-toggle="tooltip" title="Insert Media"><i class='material-icons'>add_photo_alternate</i>
</a>
<div class="editorInputs">
<input type="file" name="media" id="insertImage"
accept="audio/*,video/*,image/*"/>
</div>
</div>
这是我的js脚本
$('.tools a').mousedown(function(e){
let command = $(this).data('command');
if(command == 'insertImage'){
$(this).next().children('input').trigger('click');
let input = $(this).next().children();
input.on('change', function(e){
let val = $(input).val();
document.execCommand(command, false, val);
})
}
});
这是我的上传文件在烧瓶中的配置方式
app.config['SITE_UPLOADS'] = 'D:/Courses/Development/Programming/Python/LaunchCode/LC101/unit2/build-a-blog/static/site/uploads/'
app.config['ADMIN_UPLOADS'] = 'D:/Courses/Development/Programming/Python/LaunchCode/LC101/unit2/build-a-blog/static/admin/uploads/'
app.config['ALLOWED_IMAGE_EXTENSIONS'] = ['PNG', 'JPG', 'JPEG', 'SVG', 'GIF']
app.config['DATA_FILES'] = 'D:/Courses/Development/Programming/Python/LaunchCode/LC101/unit2/build-a-blog/data/'
app.config['RELATIVE_PATH_SITE'] = '../static/site/uploads/'
app.config['RELATIVE_PATH_ADMIN'] = '/static/admin/uploads/'
解决方案
所以,我意识到我必须创建一个函数来从上传文件夹中提取图像、显示它们、获取它们的 URL 并将其传递给 exec 命令。我做到了。
首先,使用单选按钮创建图库结构以查看文件。然后将图库放入引导模式中,以便在单击 execccom 和 insertImage 链接时触发。获取选中图像的 URL。将它传递给我的 js 中的 execcomand 函数。
在烧瓶端,使用 os.listdir(absolute/path/to/directory) 获取上传目录中所有文件的列表,返回文件的 python 列表。接下来通过循环列表中的文件名并将相对路径添加到文件名来创建文件网址并将信息放入字典中。将 dict 传递给 jinja2 模板并填充图库。
最后,执行js。
这是我的python代码和js代码。
def get_uploads():
list_images = os.listdir(app.config['ADMIN_UPLOADS'])
images = []
i =0
length = len(list_images)
while i < length:
img = {}
img['name'] = list_images[i]
img['url'] = os.path.join(app.config['RELATIVE_PATH_ADMIN'], list_images[i])
images.append(img)
i+=1
return images
这是我的js。
if(command == 'insertImage'){
$("#uploadsGallery").modal();
$('.ftco-animate').addClass('fadeInUp ftco-animated')
let check = $(this).next().find('input.form-check-input');
let val;
check.on('change', function(e){
val = $(this).val();
});
$('#insertImg').click(function (e) {
r.setStart(editDiv, lastCaretPos);
r.setEnd(editDiv, lastCaretPos);
s.removeAllRanges();
s.addRange(r);
document.execCommand(command, false, val);
check.prop('checked', false);
});
}
推荐阅读
- javascript - 以角度 10 提交表单后无法清除 ngx-mat-intl-tel-input
- c# - 隐藏表格并显示
- python-3.x - 为什么 sphinx-build(与 Python 3.8.6 一起安装)使用 Python 3.8.2?
- android - java.lang.IllegalArgumentException: 找不到 (android:id/content) 的视图
- c# - 实体框架核心(使用 mysql)模型首先 apporach 如何运行自定义查询以获得一些计数
- azure - 错误:找不到具有指定模式的包:D:\a\1\s\**\*.zip
- conda - 在全新安装康达时,康达本身出现错误 ResolvePackageNotFound
- python - ValueError: "ResizeBilinear" op: 第二个输入,也就是输出大小,必须有 int32 类型的元素
- .net-core - Docusign JWT 身份验证 dotnet 核心问题
- rxjs - 如何改进 RxJS 代码以仅将函数应用于第一次发射