zoukankan      html  css  js  c++  java
  • 前端自动提示功能插件-typeahead

      typeahead

    https://npm.taobao.org/package/npm-typeahead

    Build Status

    A lightweight web-app that implements typeahead search functionality for npm packages.

    Try it out here: http://npm-typeahead.herokuapp.com

    The Motivation

    npm-typeahead was put together as part of an article for CODE Magazine. It's an attempt to demonstrate Node.js best practices, and covers:

    https://github.com/twitter/typeahead.js

    typeahead.js is a fast and fully-featured autocomplete library http://twitter.github.com/typeahead.js/

    typeahead.js

    Inspired by twitter.com's autocomplete search functionality, typeahead.js is a flexible JavaScript library that provides a strong foundation for building robust typeaheads.

    The typeahead.js library consists of 2 components: the suggestion engine, Bloodhound, and the UI view, Typeahead. The suggestion engine is responsible for computing suggestions for a given query. The UI view is responsible for rendering suggestions and handling DOM interactions. Both components can be used separately, but when used together, they can provide a rich typeahead experience.

    例子

     npm包

    https://www.npmjs.com/

    https://twitter.github.io/typeahead.js/examples/

    $(document).ready(function() {
    
      // the basics
      // ----------
    
      var substringMatcher = function(strs) {
        return function findMatches(q, cb) {
          var matches, substringRegex;
    
          // an array that will be populated with substring matches
          matches = [];
    
          // regex used to determine if a string contains the substring `q`
          substrRegex = new RegExp(q, 'i');
    
          // iterate through the pool of strings and for any string that
          // contains the substring `q`, add it to the `matches` array
          $.each(strs, function(i, str) {
            if (substrRegex.test(str)) {
              matches.push(str);
            }
          });
    
          cb(matches);
        };
      };
    
      var states = ['Alabama', 'Alaska', 'Arizona', 'Arkansas', 'California',
        'Colorado', 'Connecticut', 'Delaware', 'Florida', 'Georgia', 'Hawaii',
        'Idaho', 'Illinois', 'Indiana', 'Iowa', 'Kansas', 'Kentucky', 'Louisiana',
        'Maine', 'Maryland', 'Massachusetts', 'Michigan', 'Minnesota',
        'Mississippi', 'Missouri', 'Montana', 'Nebraska', 'Nevada', 'New Hampshire',
        'New Jersey', 'New Mexico', 'New York', 'North Carolina', 'North Dakota',
        'Ohio', 'Oklahoma', 'Oregon', 'Pennsylvania', 'Rhode Island',
        'South Carolina', 'South Dakota', 'Tennessee', 'Texas', 'Utah', 'Vermont',
        'Virginia', 'Washington', 'West Virginia', 'Wisconsin', 'Wyoming'
      ];
    
      $('#the-basics .typeahead').typeahead({
        hint: true,
        highlight: true,
        minLength: 1
      },
      {
        name: 'states',
        source: substringMatcher(states)
      });
    
      // bloodhound
      // ----------
    
      // constructs the suggestion engine
      var states = new Bloodhound({
        datumTokenizer: Bloodhound.tokenizers.whitespace,
        queryTokenizer: Bloodhound.tokenizers.whitespace,
        // `states` is an array of state names defined in "The Basics"
        local: states
      });
    
      $('#bloodhound .typeahead').typeahead({
        hint: true,
        highlight: true,
        minLength: 1
      },
      {
        name: 'states',
        source: states
      });
    
      // prefetch
      // --------
    
      var countries = new Bloodhound({
        datumTokenizer: Bloodhound.tokenizers.whitespace,
        queryTokenizer: Bloodhound.tokenizers.whitespace,
        // url points to a json file that contains an array of country names, see
        // https://github.com/twitter/typeahead.js/blob/gh-pages/data/countries.json
        prefetch: '../data/countries.json'
      });
    
      // passing in `null` for the `options` arguments will result in the default
      // options being used
      $('#prefetch .typeahead').typeahead(null, {
        name: 'countries',
        source: countries
      });
    
      // remote
      // ------
    
      var bestPictures = new Bloodhound({
        datumTokenizer: Bloodhound.tokenizers.obj.whitespace('value'),
        queryTokenizer: Bloodhound.tokenizers.whitespace,
        prefetch: '../data/films/post_1960.json',
        remote: {
          url: '../data/films/queries/%QUERY.json',
          wildcard: '%QUERY'
        }
      });
    
      $('#remote .typeahead').typeahead(null, {
        name: 'best-pictures',
        display: 'value',
        source: bestPictures
      });
    
      // default suggestions
      // -------------------
    
      var nflTeams = new Bloodhound({
        datumTokenizer: Bloodhound.tokenizers.obj.whitespace('team'),
        queryTokenizer: Bloodhound.tokenizers.whitespace,
        identify: function(obj) { return obj.team; },
        prefetch: '../data/nfl.json'
      });
    
      function nflTeamsWithDefaults(q, sync) {
        if (q === '') {
          sync(nflTeams.get('Detroit Lions', 'Green Bay Packers', 'Chicago Bears'));
        }
    
        else {
          nflTeams.search(q, sync);
        }
      }
    
      $('#default-suggestions .typeahead').typeahead({
        minLength: 0,
        highlight: true
      },
      {
        name: 'nfl-teams',
        display: 'team',
        source: nflTeamsWithDefaults
      });
    
      // custom templates
      // ----------------
    
      $('#custom-templates .typeahead').typeahead(null, {
        name: 'best-pictures',
        display: 'value',
        source: bestPictures,
        templates: {
          empty: [
            '<div class="empty-message">',
              'unable to find any Best Picture winners that match the current query',
            '</div>'
          ].join('
    '),
          suggestion: Handlebars.compile('<div><strong>{{value}}</strong> – {{year}}</div>')
        }
      });
    
      // multiple datasets
      // -----------------
    
      var nbaTeams = new Bloodhound({
        datumTokenizer: Bloodhound.tokenizers.obj.whitespace('team'),
        queryTokenizer: Bloodhound.tokenizers.whitespace,
        prefetch: '../data/nba.json'
      });
    
      var nhlTeams = new Bloodhound({
        datumTokenizer: Bloodhound.tokenizers.obj.whitespace('team'),
        queryTokenizer: Bloodhound.tokenizers.whitespace,
        prefetch: '../data/nhl.json'
      });
    
      $('#multiple-datasets .typeahead').typeahead({
        highlight: true
      },
      {
        name: 'nba-teams',
        display: 'team',
        source: nbaTeams,
        templates: {
          header: '<h3 class="league-name">NBA Teams</h3>'
        }
      },
      {
        name: 'nhl-teams',
        display: 'team',
        source: nhlTeams,
        templates: {
          header: '<h3 class="league-name">NHL Teams</h3>'
        }
      });
    
      // scrollable dropdown menu
      // ------------------------
    
      $('#scrollable-dropdown-menu .typeahead').typeahead(null, {
        name: 'countries',
        limit: 10,
        source: countries
      });
    
      // rtl
      // ---
    
      var arabicPhrases = new Bloodhound({
        datumTokenizer: Bloodhound.tokenizers.whitespace,
        queryTokenizer: Bloodhound.tokenizers.whitespace,
        local: [
          "الإنجليزية",
          "نعم",
          "لا",
          "مرحبا",
          "أهلا"
        ]
      });
    
      $('#rtl-support .typeahead').typeahead({
        hint: false
      },
      {
        name: 'arabic-phrases',
        source: arabicPhrases
      });
    });

    Bootstrap typeahead

    https://github.com/bassjobsen/Bootstrap-3-Typeahead

    Using JSON objects instead of simple strings
    
    You can add all the properties you wish on your objects, as long as you provide a "name" attribute OR you provide your own displayText method. The other values allow you to match the selected item with something in your model.
    
    var $input = $(".typeahead");
    $input.typeahead({
      source: [
        {id: "someId1", name: "Display name 1"},
        {id: "someId2", name: "Display name 2"}
      ],
      autoSelect: true
    });
    $input.change(function() {
      var current = $input.typeahead("getActive");
      if (current) {
        // Some item from your model is active!
        if (current.name == $input.val()) {
          // This means the exact match is found. Use toLowerCase() if you want case insensitive match.
        } else {
          // This means it is only a partial match, you can either add a new item
          // or take the active if you don't want new items
        }
      } else {
        // Nothing is active so it is a new value (or maybe empty value)
      }
    });
  • 相关阅读:
    DOM attributes and properties
    SVN目录对号图标(更新、冲突)不显示
    GIS空间参考及坐标转换
    ArcGIS Engine开发之旅09--几何对象和空间参考
    ArcGIS Engine开发之旅08--和查询相关的对象和接口
    ArcGIS Engine开发之旅07---文件地理数据库、个人地理数据库和 ArcSDE 地理数据库中的栅格存储加以比较 、打开栅格数据
    ArcGIS Engine开发之旅05---空间数据库
    10.Action中的method属性
    11.使用ForwardAction实现页面屏蔽。
    9.初识拦截器
  • 原文地址:https://www.cnblogs.com/lightsong/p/10242166.html
Copyright © 2011-2022 走看看