• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
攻城狮的世界我不懂——lmky
梦想还是要有的!
博客园    首页    新随笔    联系   管理    订阅  订阅
div模拟文本框textarea

需求:利用highlight.js对文本框中的内容进行高亮显示

1.highlight.js使用

js中:<script src="js/highlight/highlight.pack.js"></script>

  <script type="text/javascript">

    hljs.initHighlightingOnLoad();//SQL高亮显示

    $(document).ready(function() {

      $("pre code").each(function(i, block) {

        hljs.highlightBlock(block);

      });

    });

  </script>

html中:<pre> <code class="lang-javascript"> 内容</code> </pre>

2.highlight.js应用于<textarea>无效,因而用 div模拟文本框textarea

无效示例:<pre>

       <code>

          <textarea id="sql" rows="14" cols="80" name="sqlStatement">

            <s:property value="udq.sqlStatement"/>

          </textarea>
                        </code>

     </pre>

有效div模拟文本框:<div id="sql"  contenteditable placeholder="请输入文字">

           <pre>

            <code>

              <s:property value="udq.sqlStatement"/>

            </code>

           </pre>
                          </div>

对于<pre><code>中的内容不随div的宽度换行问题,应用css样式:

  white-space: pre-wrap;
  word-wrap: break-word;

 

其中:介绍下HTML5里contenteditable属性:(参考https://w3c.github.io/editing/contentEditable.html#contenteditable)

它主要的属性值有:

[html] view plain copy
  1. contenteditable="inherit"  
  2. contenteditable=""  
  3. contenteditable="events"  
  4. contenteditable="caret"  
  5. contenteditable="typing"  
  6. contenteditable="plaintext-only"  
  7. contenteditable="true"  
  8. contenteditable="false"  

其实在模拟文本框时,常用的就是"plaintext-only"、"true","plaintext-only"可以实现可以让编辑区域只能键入纯文本

其实css中有一个属性(user-modify)也能实现让元素内只能输入纯文本,但是由于目前好像只有webkit内核支持(-webkit-),所以效果没上面好。

 

posted on 2017-08-17 14:50  limeiky  阅读(1769)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3