关于 div 的 contenteditable 使用,placeholder 和 复制图片显示并上传

当使用文本编辑的时候,首先会使用 textarea ,但是,这个里面不能加入其它标签,也就是不能富文本化。 于是可以使用 contenteditable

就是给 div 加上该属性。就变得丰富起来。使用的时候,发现有两个问题。

1、placeholder 无法正常使用,解决办法,是加上一段css:

.con:empty:before{
		    content: attr(placeholder);
		    color:#bbb;
		}
		.con:focus:before{
		    content:none;
		}

2、复制,或者用 qq 微信 截图只会,在编辑器内,按 ctr+v 不能将图片复制到编辑器内,解决办法是 监听 事件  paste, 这个事件,目前来说兼容不是很好,但是 谷歌 火狐 等都能正常使用

下面给出完整代码:

<!DOCTYPE html>
<html lang="zh">
<head>
	<meta charset="UTF-8" />
	<meta name="viewport" content="width=device-width, initial-scale=1.0" />
	<meta http-equiv="X-UA-Compatible" content="ie=edge" />
	<title>Document</title>

	<style type="text/css">
		*{
			padding: 0;
			margin: 0;
		}
		div{
			width: 800px;
			height: 600px;
			border: 1px solid #ccc;
			margin:  20px auto;
		}
		div img{
			max-width: 80%;
		}
		.con:empty:before{
		    content: attr(placeholder);
		    color:#bbb;
		}
		.con:focus:before{
		    content:none;
		}
	</style>
</head>
<body>
	<div class="con" contenteditable="true" placeholder="请输入描述内容..."  id="edit"></div>
</body>

<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript">

//document.execCommand(‘InsertImage‘, false, filePath);

$("#edit").on("paste",function(e){
	var  d = e.originalEvent;
	if(d&&d.clipboardData) {
		var clipboardData = d.clipboardData;
		//兼容写法,优先取 files
		if(clipboardData.files && clipboardData.files.length > 0){
			console.log("-------files----");
			mapFile(clipboardData.files);
			return ;
		}
		if (clipboardData.items && clipboardData.items.length > 0) {
			console.log("------items-----------")
			mapFile(clipboardData.items);
            return ;
        }

	}
});

function mapFile(files){
	for(var i = 0; i < files.length; i++){
		var c = files[i];
		if(c.type && c.type.split("/")[0] == "image"){
			getBase64(files[i]).then(function(ret){
				document.execCommand("insertImage",false,ret);
			}).catch(function(ret){});
		}
	}
}

function getBase64(img) {
	return new Promise(function(resolve,reject){
		  const reader = new FileReader();
		  reader.addEventListener(‘load‘, () =>{resolve(reader.result)});
		  reader.readAsDataURL(img);
	})

}

</script>
</html>

  

 效果图

 

原文地址:https://www.cnblogs.com/muamaker/p/10270824.html

时间: 2024-08-03 12:46:26

关于 div 的 contenteditable 使用,placeholder 和 复制图片显示并上传的相关文章

div中粘贴图片并上传服务器 div中拖拽图片文件并上传服务器

应用简介:此文主要是描述如何在前端div中直接ctrl+v 粘贴图片,并上传到服务器,包括拖拽图片文件到div中 应用场景描述:用QQ或者其它切图软件截图,在指定的div中ctrl+v 粘贴并显示,点击上传按钮,图片上传到服务器.类似实现了此功能的网站有 知乎,强力建议博客园实现此功能,                     写博客时插入图片方便的多. 适用环境:本代码目前适用谷歌浏览器,其它浏览器需要稍微改良一下即可,问题不大. 开发环境:vs2015 mvc 不说废话了,开始吧: 1:首先

div的contenteditable和placeholder蹦出的火花

今天在做手机端发布描述内容时,需要实现换行,还需要有plachholder. 在文本框中换行自然想到了textarea. 问题似乎已经解决了,但是当内容发布后,在html中显示换行都丢失了. 这个时候就用到了contenteditable和placeholder <div class="con" contenteditable="true" placeholder="请输入描述内容..."></div> .con:empt

img超出div width时, jQuery动态改变图片显示大小

参考: 1. http://blog.csdn.net/roman_yu/article/details/6641911 2. http://www.cnblogs.com/zyzlywq/archive/2012/02/23/2364292.html

DIV实现CSS 的placeholder效果

placeholder是HTML5中input的属性,但该属性并不支持除input以外的元素 但我们可以使用Css before选择器来实现完全相同的效果 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Div+placeholder</title> <style> .rich{ color:

可编辑DIV (contenteditable=&quot;true&quot;) 在鼠标光标处插入图片或者文字

近期需开发一个DIV做的编辑器,插入表情图片可直接预览效果,仔细参考了下百度贴吧的过滤粘贴过来文件的THML代码,自己整理了下.写出来只是和大家分享下,我自己也不大懂,经过努力,幸好搞定. 蛋疼的事情出来了,当编辑框失去焦点时候,再插入图片时候总是插入在最前面(谷歌和火狐,IE没问题).还没搞定,,, <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/

复制文件(上传至共享文件夹)

复制文件(上传至共享文件夹) 功  能:复制文件.也可以指定是否覆盖同名的目标文件. 语  法:FileCopy ( sourcefile , targetfile {, replace}) 参  数: sourcefile:string 类型,指定要复制文件的名称(源文件名称): targetfile:string 类型,指定要复制到哪一个文件(目标文件名称): replace:Boolean类型,指定当目标文件已经存在时,是否覆盖同名文件. True --- 覆盖同名文件: False --

node复制文件夹,压缩zip,上传

一:用到的模块和简单介绍 npm文档:request :node请求的模块,可以给用程序请求服务器的接口https://www.npmjs.com/package/requestfs:读写文件的,很常用https://www.npmjs.com/package/fspath:路径,各种给文件夹弄路径什么的https://www.npmjs.com/package/pathjs-cookie:获取cokie的,在请求的时候需要用到https://www.npmjs.com/package/js-c

ASP.NET中的文件操作(文件信息,新建,移动,复制,重命名,上传,遍历)(亲测详细)

做了几天的文件操作,现在来总结一下,错误之处,还望指点!以文件为例,如果对文件夹操作,基本上将File换为Directory即可(例:FileInfo file = new FileInfo(Path);与DirectoryInfo directory = new DirectoryInfo (Path);) 1获取文件信息 在知道文件相对路径的情形,下面代码可以获取文件的详细信息 1 public static void fileinfo(string Path) 2 { 3 Path = S

gd库复制图片做水印

将复制源图片的某个位置复制到目标图片中,不能调整大小 imagecopy(目标图片画布,复制源画布,目标画布左上角x,y,源画布左上角x,y,复制图片的宽,高); 允许调整大小 imagecopyresampled(目标图片画布,复制源画布,目标画布左上角x,y,源画布左上角x,y,目标画布的宽,高,复制源图片的宽,高); 可以设置透明度 imagecopy(目标图片画布,复制源画布,目标画布左上角x,y,源画布左上角x,y,复制图片的宽,高,透明度0-100); <?php //大图画布 $i