简体   繁体   中英

How do I set a max length of a string in a conteneditable table in HTML?

I have currently been making a word search maker, but I have occurred a problem. The problem is that I'me using a table with contenteditable, but how do I set a max string length. I already tried

maxlength="1"

Can anyone please help!

 #editor { background-color: turquoise; } 
 <table border="1" id="editor" width="500px" height="500px"> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> </table> 

When running to code snippet, please go fullscreen.

Please, if there are any ways, please try avoid jquery!

You can either change those to inputs, or use the following JavaScript

 var pre = onload, doc, T, oneCharOnly; // change pre to another var if using technique on different page onload = function(){ if(pre)pre(); doc = document; T = function(n, e){ var w = e || doc; return w.getElementsByTagName(n); } oneCharOnly = function(){ var tds = T('td'); for(var i=0,l=tds.length; i<l; i++){ tds[i].onkeyup = function(){ if(!this.innerHTML.match(/^.$/)){ this.contentEditable = false; } } } } oneCharOnly(); // okay to use on other pages due to scope } 
 #editor { background-color: turquoise; } 
 <table border="1" id="editor" width="500px" height="500px"> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> </table> 

You can do it using javascript:

Example:

 const table = document.querySelector('table'); const validateMaxLength = (event) => { const textLength = event.target.textContent.length; if ( textLength > 5) { event.preventDefault(); } } table.addEventListener('keydown', validateMaxLength); 
 #editor { background-color: turquoise; } 
 <table border="1" id="editor" width="500px" height="500px"> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> <tr> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> <td contenteditable="true">&nbsp;</td> </tr> </table> 

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM