zoukankan      html  css  js  c++  java
  • 关于 div 的 contenteditable 使用,placeholder 和 复制图片显示并上传,按住 enter+ctrl 内容换行

    当使用文本编辑的时候,首先会使用 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{
    			 800px;
    			height: 600px;
    			border: 1px solid #ccc;
    			margin:  20px auto;
    		}
    		div img{
    			max- 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>
    

      

     效果图

     3、当 contenteditable 作为聊天输入框的时候,就需要按住 enter + ctrl 换行, 按 enter 发送消息

      

    $("#textarea").keydown(function($event){
            	 var keycode = window.event ? $event.keyCode : $event.which;
            	   var evt = $event || window.event;
             	
                if (keycode == 13 && !(evt.ctrlKey)) {
                   
                    $event.preventDefault();
                    return false;
                }
                // ctrl+回车-->换行
                if (evt.ctrlKey && evt.keyCode == 13) {
                   if (window.getSelection) {
    				      var selection = window.getSelection(),
    				      range = selection.getRangeAt(0),
    				      br = document.createElement("br"),
    				      textNode = document.createTextNode("u00a0"); //Passing " " directly will not end up being shown correctly
    				      range.deleteContents();//required or not?
    				      range.insertNode(br);
    				      range.collapse(false);
    				      range.insertNode(textNode);
    				      range.selectNodeContents(textNode);
    				      selection.removeAllRanges();
    				      selection.addRange(range);
    				      document.execCommand("delete");
    				      return false;
    				  }
                    return false;
                }
    
            });
    

      

  • 相关阅读:
    BZOJ 2957: 楼房重建
    那些年犯下的逗比错误
    BZOJ 2165: 大楼
    BZOJ 2115: [Wc2011] Xor
    bzoj 2006 [NOI2010]超级钢琴——ST表+堆
    bzoj 4571 [Scoi2016]美味——主席树
    bzoj 1014 [JSOI2008]火星人prefix——splay+哈希
    bzoj 2962 序列操作——线段树(卷积?)
    CF 809D Hitchhiking in the Baltic States——splay+dp
    bzoj 3489 A simple rmq problem——主席树套线段树
  • 原文地址:https://www.cnblogs.com/muamaker/p/10270824.html
Copyright © 2011-2022 走看看