RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1526218
Accepted
Alexander Lonberg
Alexander Lonberg
Asked:2023-06-18 00:12:26 +0000 UTC2023-06-18 00:12:26 +0000 UTC 2023-06-18 00:12:26 +0000 UTC

<INPUT PLACEHOLDER> 在任何 HTML/CSS/JS 技术上模拟 <DIV CONTENTEDITABLE>?[解决了]

  • 772

我正在尝试<input placeholder="...">模拟<div contenteditable>.

首先想到的是添加::before,关注正在编辑的元素后,<div ...>删除包含的类。

问题:尝试运行代码并单击文本“编辑字段...”,就像您通常所做的那样<input type=text>- 焦点一切正常,但文本光标丢失。我猜是因为点击是在::before. 如果您单击一个可用空间(右侧),一切都会按预期进行 -placeholder它消失并且光标出现在该字段中,之后您可以立即打印。

问题:如何达到预期的效果?当然没有任何额外的层。也许有一些 JS / API / CSS 允许您使元素::before不与其父元素重叠?

已解决:@Grundy CSS pointer-events 的第一条评论:无;

const { createApp, ref } = Vue

const comp = {
  setup() {
    const showPh = ref(true)
    return {
      showPh
    }
  },
  template: `
   <div
      v-bind:class="['edit', {['edit-ph']: showPh}]"
      contenteditable="true"
      @focus="() => {showPh = false}"
      @blur="({target}) => {target.textContent = '';showPh = true}"
   ></div>

   <p>Для сброса надо кликнуть в любом месте.</p>`
}

createApp(comp).mount('#app')
body {
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  font-size: 24px;
}

.edit {
  border: solid 1px rgb(182, 182, 182);
  padding: 0.2em;
}

.edit-ph::before {
  position: relative;
  content: 'Отредактируйте поле ...';
  color: rgb(182, 182, 182);
  cursor: text;
  /* РЕШЕНИЕ */
  pointer-events: none;
}
<script src="https://unpkg.com/vue@next"></script>
<div id="app"></div>

javascript
  • 1 1 个回答
  • 18 Views

1 个回答

  • Voted
  1. Best Answer
    Grundy
    2023-06-18T01:14:40Z2023-06-18T01:14:40Z

    你可以设置pointer-events :none在伪元素上,然后点击它会被忽略

    const { createApp, ref } = Vue
    
    const comp = {
      setup() {
        const showPh = ref(true)
        return {
          showPh
        }
      },
      template: `
       <div
          v-bind:class="['edit', {['edit-ph']: showPh}]"
          contenteditable="true"
          @focus="() => {showPh = false}"
          @blur="({target}) => {target.textContent = '';showPh = true}"
       ></div>
    
       <p>Для сброса надо кликнуть в любом месте.</p>`
    }
    
    createApp(comp).mount('#app')
    body {
      font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
      font-size: 24px;
    }
    
    .edit {
      border: solid 1px rgb(182, 182, 182);
      padding: 0.2em;
    }
    
    .edit-ph::before {
      pointer-events: none;
      position: relative;
      content: 'Отредактируйте поле ...';
      color: rgb(182, 182, 182);
      cursor: text;
    }
    <script src="https://unpkg.com/vue@next"></script>
    <div id="app"></div>

    • 2

相关问题

  • 第二个 Instagram 按钮的 CSS 属性

  • 由于模糊,内容不可见

  • 弹出队列。消息显示不正确

  • 是否可以在 for 循环中插入提示?

  • 如何将 JSON 请求中的信息输出到数据表 Vuetify vue.js?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5