首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在只有一个具有相同类的li上预览文本

在只有一个具有相同类的li上预览文本
EN

Stack Overflow用户
提问于 2015-03-13 20:57:08
回答 1查看 82关注 0票数 0

我有一个<ul>,当我在输入框中输入文本时,将在列表中预览文本。我还有一个按钮,可以在<ul>中添加更多的<ul>。我想要它,以便当我输入文本框时,文本会在那个<li>上预览。

我的代码:

代码语言:javascript
运行
复制
<ul class="nav nav-list nav-stacked" id="courseNav">
    <li class="title">
        <a href="#">Overview</a>
    </li>
    <li class="topics" style="margin-top: -12px">
        <a href="#">Topic</a>
    </li>
    <li class="topics">
        <a href="#">Topic</a>
    </li>
    <li class="topics">
        <a href="#">Topic</a>
    </li>
</ul>

我的按钮代码:

代码语言:javascript
运行
复制
$('#addCourse').click(function() {
    // adds a li to the courseNav
    $('#courseNav').append('<li class="newTopic" id="newLi"><a href="#">Topic</a></li>');

    $('.newTopic').click(function() {
        $('#courseDiv').css('display', 'none');
        $('#topicDiv').css('display', 'block');
    }); 
});

$('#delCourse').click(function() {
    $('#newLi').remove();
});

我的预览代码:

代码语言:javascript
运行
复制
var input = $('#editorText'),
    preview = $('.topics a');

    input.keyup(function (e) {
        preview.html(input.val());
        preview.css('padding-top', '10px');
        preview.css('padding-bottom', '10px');
        preview.css('padding-right', '15px');
        preview.css('padding-left', '15px');
        preview.css('word-wrap', 'break-word');
    });

问题是文本是在所有带有<li>class“主题”上预览的。我怎么才能解决这个问题?我可以将ids分配给<li>s,但是通过按钮添加的那部分呢?

新小提琴

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-13 21:19:53

看看jsFiddle。单击时,您可以保存当前节点,而且keyup绑定必须脱离click处理程序。

代码语言:javascript
运行
复制
input.keyup(function (e){
   ...    
}

$('.topics').click(function(){
    preview = $(this).find('a');
    ...
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29041798

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档