【问题标题】:Styling Radio buttons underlining text样式单选按钮下划线文本
【发布时间】:2013-03-28 02:21:44
【问题描述】:

所以我会得到文本:“牛津......真实的例子”和需要下划线并在下方有单选选项的短语(图片中没有单选按钮,但我还需要供用户选择的单选按钮)。

如何使用 css 和 javascript 实现这一点?

感谢大家的帮助。

【问题讨论】:

  • 你试过什么?
  • 嗨,Derek,我对将选项放置在下划线文本下方的部分感到困惑。

标签: javascript html css styling underline


【解决方案1】:

我相信这就是你想要的:

  http://jsfiddle.net/DerekL/NRpcn/

(为了简单起见,我在示例中使用了jQuery

var list = ["The", "well known", "meanings", "to give"];    //word list
var output = $("#output"),
    html = output.html();

for(var i = 0; i < list.length; i++) {
    //Wrap each keyword with <span>
    html = html.replace(new RegExp("(" + list[i] + ")", "i"), "<span>$1</span>");
}

output.html(html);

$("p>span").each(function (i) {              //Create the index for each one
    var x = $(this).offset().left,                  //Get the x
        y = $(this).offset().top,                   //Get the y
        width = +$(this).width(),                   //Get the width
        $select = $("<div>").addClass("select");

    $select.css({
        top: y + 20,
        left: x,
        width: width
    })
        .html(String.fromCharCode(65 + i))          //Set the index (A, B, C...)
        .appendTo("body");                          //Append it to the container
});

(当您调整窗口大小时,该示例将自动重新计算位置。)

这是实现它的一种方法,还有许多其他方法可以实现它。我个人更喜欢这个,因为这不是很容易理解。

【讨论】:

  • 谢谢德里克。那很好。顺便说一句,我能问你 $('p>span') 和 $('p span') 有什么区别吗? ">" 是干什么用的?谢谢
  • @PaulHoang - 有帮助吗?
  • 是的,谢谢德里克。我已经在我的案例中尝试过它并且它有效。唯一的小问题是,因为选项是绝对定位的,它可能会与下面的文本发生冲突(例如,当句子很长,因此跨越 2 行时,选项 A 可能会覆盖下一行的文本)。是否有强制下一行后退一点余量?
  • @PaulHoang - 在我的示例中,我增加了 line-height 以增加行间距。
  • 我想知道是否有更好的解决方案(因为 line-height 将应用于所有)。但它有效。谢谢德里克。
猜你喜欢
  • 2012-10-12
  • 2012-04-09
  • 2016-03-13
  • 2012-04-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-01-21
相关资源
最近更新 更多