HTML - Keep placeholder when user types

前端 未结 5 626
清酒与你
清酒与你 2020-12-10 13:36

I have an input like this:


When I type something in the input the placeholder t

相关标签:
5条回答
  • 2020-12-10 14:01

    You could try doing something like this:

    HTML:

    <div class="wrapper">
      <input type="text">
      <span class="placeholder">Placeholder</span>
    </div>
    

    CSS:

    .wrapper{
      position: relative;
    }
    
    input {
      font-size: 14px;
      height: 40px;
    }
    
    .placeholder {
      position: absolute;
      font-size:25px;
      pointer-events: none;
      left: 1px;
      top: 1px;
      transition: 0.1s ease all;
    }
    
    input:focus ~ .placeholder{
      top: 1px;
      font-size: 11px;
    }
    

    JSFiddle

    0 讨论(0)
  • 2020-12-10 14:02

    This could be done by using the 'onchange' handler. You would write a fancy function that would concat the remainder of the placeholder onto what the user has typed, and would also place the cursor at the end of the user's text.

    Here's some untested, incomplete js/psuedocode to give you an idea:

    userTextLength: 0, // measure of how many chars the user has typed; need this because the length itself won't be a valid measure, since we're modifying it in place. Note that we're using the DOM as a source of truth here... alternative method would be to store the user's text itself here, but let's run with this.
    placeholder: "xx/yy/zz",
    onchange: function() {
      boxText = document.querySelector('#elem').value;
      if (boxText.length === 1) { // special handling for the first character they type. (Using placeholder text at first.)
        this.userTextLength++;
        placeholder = boxText.slice(userTextLength);
        userText = boxText.slice(0, userTextLength);
        document.querySelector('#elem').innerHTML = userText + placeholder;
      }
      if (boxText.length < placeholder.length) { // this would mean they used backspace, which also needs to be handled.
    
      }
      else { // the normal case, should look quite similar to the first if block
        this.userTextLength += 1;
        userInput = 
      }
    }
    

    Something I haven't handled here is the cursor focusing. That will need an 'onfocus' event, and will use the userTextLength property as well to decide where to place it. For some help on doing that, this answer looks like it should be helpful.

    0 讨论(0)
  • 2020-12-10 14:11

    Hard to think of a good usecase for such a behaviour, as it is blocking some of the users input.

    An easy way would be to use input::after but this is not supported by any browser right now (thanks @JukkaK.Korpela).

    But you can use a wrapper element and a data attribute, as follows:

    <div class="placeholder" data-placeholder="my placeholder">
        <input value="My text" />  
    </div>
    

    With this css:

    .placeholder
    {
        position: relative;
    }
    
    .placeholder::after
    {
        position: absolute;
        left: 5px;
        top: 3px;
        content: attr(data-placeholder);
        pointer-events: none;
        opacity: 0.6;
    }
    

    Resulting in: enter image description here

    Click here for jsFiddle demo.


    Since you will have to do a lot of tweaking to make this look good, you may also consider using the wrapping <div> element as a input "look alike":

    <div class="editable" data-placeholder="my placeholder">
        <input type="text" value="my Text" />
    </div>
    

    CSS:

    .editable
    {
        position: relative;
        border: 1px solid gray;
        padding: 3px;
        background-color: white;
        box-shadow: rgba(0,0,0,0.4) 2px 2px 2px inset;
    }
    
    .editable > input
    {
        position: relative;
        z-index: 1;
        border: none;
        background-color: transparent;
        box-shadow: none;
        width: 100%;
    }
    
    .editable::after
    {
        position: absolute;
        left: 4px;
        top: 5px;
        content: attr(data-placeholder);
        pointer-events: none;
        opacity: 0.5;
        z-index: 1;
    }
    

    Click here for the Demo 3. (with mocked <input />)

    Click here for the Demo 2. (with contenteditable)

    0 讨论(0)
  • 2020-12-10 14:16

    Much better solution with ease effect via CSS. Take a look: http://jsfiddle.net/csdtesting/wbqq129q/

    • Before typing:

    enter image description here

    • While typing:

    enter image description here

    Code:

    #login {
      font-size: 12px;
      margin: 0 auto;
      width: 700px;
    }
    #login li {
      float: left;
      list-style: none;
      margin-left: 30px;
      position: relative;
    }
    #login li:first-child {
      margin-left: 0;
    }
    label {
      line-height: 40px;
      position: absolute;
      right: 120px;
      top: 0;
      bottom: 0;
      -moz-transition: 0.3s right ease;
      -ms-transition: 0.3s right ease;
      -o-transition: 0.3s right ease;
      -webkit-transition: 0.3s right ease;
      transition: 0.3s right ease;
      z-index: 0
    }
    input {
      color: transparent;
      font-size: 12px;
      height: 35px;
      -moz-border-radius: 3px;
      -webkit-border-radius: 3px;
      border-radius: 3px;
      -moz-transition: 0.3s all ease;
      -ms-transition: 0.3s all ease;
      -o-transition: 0.3s all ease;
      -webkit-transition: 0.3s all ease;
      transition: 0.3s all ease;
    }
    input[type="email"],
    input[type="password"] {
      border: 1px solid #ccc;
      height: 35px;
      padding: 0 10px;
      width: 240px;
      position: relative;
      -moz-box-shadow: inset 0 0 10px rgba(0, 0, 0, .06);
      -webkit-box-shadow: inset 0 0 10px rgba(0, 0, 0, .06);
      box-shadow: inset 0 0 10px rgba(0, 0, 0, .06);
      z-index: 2;
    }
    input[type="email"] {
      color: rgba(47, 130, 194, .8);
    }
    /* Placeholder */
    
    input[type="email"]:-moz-placeholder {
      color: rgba(47, 130, 194, .6);
    }
    input[type="email"]:-ms-input-placeholder {
      color: rgba(47, 130, 194, .6);
    }
    input[type="email"]::-webkit-input-placeholder {
      color: rgba(47, 130, 194, .6);
    }
    /* Label */
    
    input[type="email"] + label {
      color: rgb(47, 130, 194);
    }
    input:focus + label {
      right: 10px;
    }
    input[type="email"]:focus,
    input[type="password"]:focus {
      background-color: rgba(255, 255, 255, .8);
    }
    /* Submit */
    
    input[type="submit"] {
      background-color: #333;
      background: -moz-linear-gradient(bottom, #333, #444);
      background: -ms-linear-gradient(bottom, #333, #444);
      background: -o-linear-gradient(bottom, #333, #444);
      background: -webkit-linear-gradient(bottom, #333, #444);
      background: linear-gradient(bottom, #333, #444);
      border: 1px solid #222;
      color: #fff;
      cursor: pointer;
      height: 35px;
      width: 110px;
    }
    <form id="login">
      <ul>
        <li>
          <input id="email" name="email" placeholder="Your Email" title="Your Email" type="email" required />
          <label for="email">Your Email</label>
        </li>
      </ul>
    </form>

    0 讨论(0)
  • 2020-12-10 14:16

    it is impossible, if it is, it will be very unattractive. But i have an idea can help you with jquery support.

    You can view the demo here: http://hangaumy.com/order/

    When you type, it will automatically add words in it (look like placeholder)

    0 讨论(0)
提交回复
热议问题