文本在html5中突出显示

我正在尝试使用uni代码编写一个telugu文本,以便我可以通过根据声音更改为多种颜色来突出显示文本。 为此我使用html5和js

<div  class="pa">&#3114;</div>
<div  class="paa">&#3114;&#3134;</div>

通过使用

$("#paa").animate({ color: "blue" }, 500); 

我可以改变字母的整个颜色,但现在我想突出显示该字母的一部分。 请建议如何完成。


有几个CSS技巧来伪造background-clip:text; 或类似SVG的东西。

span {
  position:relative;
  color:green;
}
span:before {
  position:absolute;
  top:0;
  left:0;
  overflow:hidden;
  content:attr(data-text);
  color:blue;
  height:0.7em;
  overflow:hidden;
  animation: txtclr 4s infinite;
}
p {
  background:yellow;
  color:rgba(128, 0, 128 , 0.5);
  font-size:2em;
  font-weight:bold;
  background:linear-gradient(to bottom,lightgray 50%,yellow 50%);
  display:table;/* demo purpose to shrink to text size*/
  box-shadow:inset -3em 0 rgba(100,100,100,0.5);
  
}
@keyframes txtclr {
  0% {
    height:50%;
  }
  25%,75%{
    height:0;
    width:0;
  }
  50%{
    height:100%;
  }
}
<p><span data-text="my text">my text</span> and some other text </p>

所有语言都是可行的,但并不容易。 在下面的例子中,我为某些字母上色了重音。 http://jsfiddle.net/07hh3z2n/5/

提示是使用CSS获取没有宽度的inline-block

.phantom {
    display: inline-block;
    color: red;
    width: 0;
    overflow: visible;
}

如果你想突出显示的部分是现有的Unicode字符,这将工作正常。 否则,您可以尝试使用(或创建)带有字母部分的特殊字体来突出显示。


你的意思是这样吗? 只使用CSS来将文本流过它,在这个示例中不需要javascript ;-)但是您可以随时切换出具有所需效果的类。

它所做的是使用transition属性,它允许它在诸如悬停,单击活动等事件之后在不同的css状态之间进行动画处理。

要突出显示部分字母,您需要添加该HTML元素两次。 我用彩色和朴素做了什么。 这也适用于单个字母。 您需要将它们设置为绝对位置并将它们包裹在相对的div中。 通过这样做,他们将自己定位到相对包装div的左上角位置(在我的示例中)。 这样,如果您使用<span>作为示例的包装,则可以保留文本流

然后,您将其中一个设置为宽度0,或者设置为您希望覆盖另一个字母一半的宽度

在我的例子中,只有一半是红色,另一半(一半是红色)。

如果你想覆盖上半场,你可以打高度。

http://jsfiddle.net/L9L8L966/1/

    #container {
        font-size:40px;
        position:relative;
        background-color:#CCC;
        width:450px;
        height:40px;
    }
    #coloured {
        position:absolute;
        z-index:2;
        top:0px;
        left:0px;
        display:block;
        width:0%;
         -webkit-transition: width 1s ease-in-out;
        -moz-transition: width 1s ease-in-out;
        -o-transition: width 1s ease-in-out;
        transition: width 1s ease-in-out;
        color:red;
        overflow:hidden;
    }
    #container:hover #coloured {
        width:100%;
    }
    #plain {
        position:absolute;
        z-index:1;
        width:100%;
        display:block;
        top:0px;
        left:0px;
        color:black;
    }


    
<div id="container">
        <div id="coloured">
            abcdefghijklmnopqrstuvwxyz
        </div>
        <div id="plain">
            abcdefghijklmnopqrstuvwxyz
        </div>
    </div>
链接地址: http://www.djcxy.com/p/23787.html

上一篇: Text highlighting in html5

下一篇: Is there a way to partially fill text with different colours?