超链接的组合框选项

时间:2014-10-18 02:38:38

标签: javascript jquery html

请注意,我有以下两组执行不同功能的代码

  1. 下拉列表设置为超链接
  2. 选择选项但没有超链接的组合框(文本框和下拉列表)
  3. 现在:我想要结合这些功能

    我的第一组代码:


    <select name="select" onChange="window.open(this.options[this.selectedIndex].value,'_blank')">
            <option value="Select City">Select City</option>
            <option value="http://www.18flats.com/city/mumbai/">Mumbai</option>
            <option value="http://www.18flats.com/city/pune/">Pune</option>
            <option value="http://www.18flats.com/city/bangalore/">Bangalore</option>
            <option value="http://www.18flats.com/city/delhi/">Delhi</option>
    </select>
    

    我的第二组代码:


     <script>
    (function( $ ) {
    $.widget( "custom.combobox", {
    _create: function() {
    this.wrapper = $( "<span>" )
    .addClass( "custom-combobox" )
    .insertAfter( this.element );
    this.element.hide();
    this._createAutocomplete();
    this._createShowAllButton();
    },
    _createAutocomplete: function() {
    var selected = this.element.children( ":selected" ),
    value = selected.val() ? selected.text() : "";
    this.input = $( "<input>" )
    .appendTo( this.wrapper )
    .val( value )
    .attr( "title", "" )
    .addClass( "custom-combobox-input ui-widget ui-widget-content ui-state-default ui-corner-left" )
    .autocomplete({
    delay: 0,
    minLength: 0,
    source: $.proxy( this, "_source" )
    })
    .tooltip({
    tooltipClass: "ui-state-highlight"
    });
    this._on( this.input, {
    autocompleteselect: function( event, ui ) {
    ui.item.option.selected = true;
    this._trigger( "select", event, {
    item: ui.item.option
    });
    },
    autocompletechange: "_removeIfInvalid"
    });
    },
    _createShowAllButton: function() {
    var input = this.input,
    wasOpen = false;
    $( "<a>" )
    .attr( "tabIndex", -1 )
    .attr( "title", "Show All Items" )
    .tooltip()
    .appendTo( this.wrapper )
    .button({
    icons: {
    primary: "ui-icon-triangle-1-s"
    },
    text: false
    })
    .removeClass( "ui-corner-all" )
    .addClass( "custom-combobox-toggle ui-corner-right" )
    .mousedown(function() {
    wasOpen = input.autocomplete( "widget" ).is( ":visible" );
    })
    .click(function() {
    input.focus();
    // Close if already visible
    if ( wasOpen ) {
    return;
    }
    // Pass empty string as value to search for, displaying all results
    input.autocomplete( "search", "" );
    });
    },
    _source: function( request, response ) {
    var matcher = new RegExp( $.ui.autocomplete.escapeRegex(request.term), "i" );
    response( this.element.children( "option" ).map(function() {
    var text = $( this ).text();
    if ( this.value && ( !request.term || matcher.test(text) ) )
    return {
    label: text,
    value: text,
    option: this
    };
    }) );
    },
    _removeIfInvalid: function( event, ui ) {
    // Selected an item, nothing to do
    if ( ui.item ) {
    return;
    }
    // Search for a match (case-insensitive)
    var value = this.input.val(),
    valueLowerCase = value.toLowerCase(),
    valid = false;
    this.element.children( "option" ).each(function() {
    if ( $( this ).text().toLowerCase() === valueLowerCase ) {
    this.selected = valid = true;
    return false;
    }
    });
    // Found a match, nothing to do
    if ( valid ) {
    return;
    }
    // Remove invalid value
    this.input
    .val( "" )
    .attr( "title", value + " didn't match any item" )
    .tooltip( "open" );
    this.element.val( "" );
    this._delay(function() {
    this.input.tooltip( "close" ).attr( "title", "" );
    }, 2500 );
    this.input.autocomplete( "instance" ).term = "";
    },
    _destroy: function() {
    this.wrapper.remove();
    this.element.show();
    }
    });
    })( jQuery );
    $(function() {
    $( "#combobox" ).combobox();
    $( "#toggle" ).click(function() {
    $( "#combobox" ).toggle();
    });
    });
    </script>
    </head>
    <body>
    <div class="ui-widget">
    <label>Your preferred programming language: </label>
    <select id="combobox">
    <option value="">Select one...</option>
    <option value="ActionScript">ActionScript</option>
    <option value="AppleScript">AppleScript</option>
    <option value="Asp">Asp</option>
    <option value="BASIC">BASIC</option>
    <option value="C">C</option>
    <option value="C++">C++</option>
    <option value="Clojure">Clojure</option>
    <option value="COBOL">COBOL</option>
    <option value="ColdFusion">ColdFusion</option>
    <option value="Erlang">Erlang</option>
    <option value="Fortran">Fortran</option>
    <option value="Groovy">Groovy</option>
    <option value="Haskell">Haskell</option>
    <option value="Java">Java</option>
    <option value="JavaScript">JavaScript</option>
    <option value="Lisp">Lisp</option>
    <option value="Perl">Perl</option>
    <option value="PHP">PHP</option>
    <option value="Python">Python</option>
    <option value="Ruby">Ruby</option>
    <option value="Scala">Scala</option>
    <option value="Scheme">Scheme</option>
    </select>
    </div>
    <button id="toggle">Show underlying select</button>
    

    第二组可以在实时here

    中看到

    忘记切换按钮,我对此不感兴趣!我想要的是重定向/超链接直接到页面链接值!

    我将与v.helpful合作的另一个选项是Go按钮,当点击GO时应该将我重定向到该页面(超链接)

    先谢谢

0 个答案:

没有答案