5

我以这里为例, Demo 6

一切正常,但是我不知道如何放置处理程序,这将从那里获得价值。也就是当你改变选择器时改变“内容”。这是选择器的代码:

    <select id="cd-dropdown" class="cd-select">
    <option value="-1" selected>Choose an animal</option>
    <option value="1" class="icon-monkey">Monkey</option>
    <option value="2" class="icon-bear">Bear</option>
    <option value="3" class="icon-squirrel">Squirrel</option>
    <option value="4" class="icon-elephant">Elephant</option>
    </select>

,但是页面上已经显示

 <div class="cd-dropdown">
    <span>Choose an animal</span>
    <input type="hidden" name="cd-dropdown">
    <ul>
        <li data-value="1"><span class="icon-monkey">Monkey</span></li>
        <li data-value="2"><span class="icon-bear">Bear</span></li>
        <li data-value="3"><span class="icon-squirrel">Squirrel</span></li>
        <li data-value="4"><span class="icon-elephant">Elephant</span></li>
    </ul>
   </div>

,我意识到发生了这种“转变”

jquery.dropdown.js

创建了 2 个表单,forma1 的 id = "f1",同样 form2 c id = "f2",一个表单确实隐藏了。穿上选择

onChange="a(this.value)"

,

function a(value){  
$('#f' + value).show() 
if (value == 1) 
    $('#f2').hide() 
else
    $('#f1').hide()
}

中性选择有效,但事实并非如此。如果控制台浏览器调用一个具有一定值的函数,例如: а(2),则一切正常输出。

所以就像把事件处理程序放在哪里,它检查隐藏字段的值???

提前致谢

4

3 回答 3

5

演示

HTML

<select id="cd-dropdown" class="cd-select">
    <option value="-1" selected>Choose an animal</option>
    <option value="1" class="icon-monkey">Monkey</option>
    <option value="2" class="icon-bear">Bear</option>
    <option value="3" class="icon-squirrel">Squirrel</option>
    <option value="4" class="icon-elephant">Elephant</option>
</select>

<div id="div1" class="animalDiv">MONKEY</div>
<div id="div2" class="animalDiv">BEAR</div>
<div id="div3" class="animalDiv">SQUIRREL</div>
<div id="div4" class="animalDiv">ELEPHANT</div>

CSS

.animalDiv {
 display:none;
}

JS/jQuery :

$(function() {
    $('#cd-dropdown').dropdown({
        gutter: 5,
        stack: false,
        delay: 100,
        slidingIn: 100,
        onOptionSelect: function(e) {
            var _counter = ($(e).html()).split('data-value="')[1].split('"')[0];
            $(".animalDiv").hide();
            $("#div" + _counter).show();
        }
    });
});​

*注意: 我应该注意到我还在 jquery.dropdown.js 中进行了更改:

val !== -1 ? classes !== undefined ? optshtml += '<li><span data-value="' + val + '" class="' + classes + '">' + label + '</span></li>' : optshtml += '<li><span data-value="' + val + '">' + label + '</span></li>' : selectlabel = label;

从到data-value_lispan

于 2012-12-19T20:22:11.830 回答
3

我不确定你到底在问什么,但我会采取行动。

我假设您正在询问如何将处理程序添加到单击“选项”之一。也就是说,当有人点击“猴子”时,你想用一个函数来处理那个点击。

通过查看插件源,我看到他们允许一个名为'onOptionSelect'. 我没有看到有关此选项的任何解释或文档,但从查看源代码来看,这是单击事件的处理程序:

this.opts.on( 'click.dropdown', function() {
        if( self.opened ) {
            var opt = $( this );
            self.options.onOptionSelect( opt );
            self.inputEl.val( opt.data( 'value' ) );
            self.selectlabel.html( opt.html() );
            self.close();
        }
   } );

在这里您可以看到他们正在调用“onOptionSelect”函数并将所选项目作为唯一参数传入。因此,当您在脚本中创建下拉列表时,请为您的处理程序添加函数:

$('#cd-dropdown').dropdown({onOptionSelect: aHandler});

function aHandler(value){  
$('#f' + value).show() 
if (value == 1) 
    $('#f2').hide() 
else
    $('#f1').hide()
}

通过这种方式,您可以编写一个处理程序并在单击选项时对该值执行任何您想要的操作。

如果您想弄清楚在“下拉菜单”中选择了哪些项目,则需要查询名称为“cd-dropdown”的“隐藏”。此隐藏输入具有选定值:

$('input[name="cd-dropdown"]').val() --> equals the selected value

我希望这是有帮助的。我认为该插件需要更多文档。

于 2012-12-19T20:23:58.513 回答
1
$('#cd-dropdown').dropdown({
            onOptionSelect: function (opt) {
                alert(opt.data('value'));
                return false;
            }
        });
于 2014-07-01T05:41:35.073 回答