javascript - 如何隐藏动态 div,除非所有 div 都有特定的类 - algolia

标签 javascript jquery html css algolia

我正在使用名为 Algolia 的服务它的工作方式类似于单页搜索设备。当用户输入要搜索的术语时,Algolia 会自动将子 div 加载到包含范围内并提供可能的建议。子 div 加载了 DOM,但子 div 的内容会根据用户输入而变化。输入字段中的每个按键都会更改 div。

找到的记录

如果结果搜索发现有效记录,则子 div 将包含如下内容:

<span id="algolia-autocomplete-listbox-0">    
    <div class="aa-dataset-1">
      <span class="aa-suggestions" style="display: block;">
        <div class="aa-suggestion">
          <div class="algolia-result">
            <div class="row">
                <div class="col nopadding">
                    <span>Dynamic data has been added</span>
                </div>
            </div>
          </div>
        </div>
      </span>
    </div>
</span>

在上面的示例中,类“aa-dataset-1”是一个包含建议的 div。 “-1”代表 Algolia 将添加的动态 div。这意味着我可以拥有一个动态 div,其类范围从“aa-dataset-1”到“aa-dataset-X”。

没有找到记录

当没有从 Algolia 返回结果时,包含的 div(“aa-dataset-X”)仍然填充有内容。返回零结果的搜索示例如下:

<div class="aa-dataset-1">
  <div class="algolia-empty">
    <span>No results were found with your current selection.</span>
  </div>
</div>

我的问题是,即使有一个子 div 类为“aa-suggestions”,类为“algolia-empty”的 div 仍然显示。下图显示了找到单个记录的示例,但仍显示类为“algolia-empty”的 div

enter image description here

显示类“algolia-empty”将始终显示,因为 Algolia 以这种方式构建了他们的产品。

问题

我想做的是将所有子 div 隐藏在“algolia-autocomplete-listbox-0”中除非每个子 div 都有一个“algolia-empty”类。请记住,这是一个单页应用程序。

可以在这里找到一个可用的 JSFiddle:http://jsfiddle.net/jandk4014/8vktn0cu/44/

更新

服务的成功结果应该是什么样的?查看下图。

enter image description here

如果您想实际查看它,请查看上面的 JSFiddle 链接。

最佳答案

我发现可以通过 Algolia 以“全局”方式设置空模板。

//Search for BR6340-02-0.250 > Success
//Search for blah > Failure

var client = algoliasearch('9G2RUKPPGE', '8860a74c330efaf0119818fcdd800126');

const indices = [
  ['SPR', 'Spacers'],
  ['SWG_SPR', 'Swage Spacers'],
  ['FF_STDF', 'Female-Female Standoffs'],
  ['SWG_STDF', 'Swage Standoffs'],
  ['MF_STDF', 'Male-Female Standoffs'],
  ['BSM', 'Ball Stud Males'],
  ['BSF', 'Ball Stud Females'],
  ['CHF', 'Chassis Fasteners'],
  ['MM_STDF', 'Male-Male Standoff'],
  ['SPR_TRQ', 'Super Torq Swage Standoffs'],
  ['CPS_1', 'Captive Panel Screw - Type 1']
];

const sources = indices.map(function(indexKeyValue) {
  var index = client.initIndex(indexKeyValue[0]);

  return {
    // source would be edited with the custom source from the other question
    source: $.fn.autocomplete.sources.hits(index, {
      hitsPerPage: 15,
    }),
    displayKey: 'code',
    templates: {
      suggestion: function(suggestion) {
        const markup = `
          <div class="row">
              <div class="col-xs-1 col-sm-1 col-md-1 nopadding">
                  <img src="${suggestion.image}" alt="" class="algolia-thumb">
              </div>
              <div class="col-xs-11 col-sm-11 col-md-11">
                  <div class="row">
                      <div class="col-xs-6 col-sm-8 col-md-8">
                          <span>${suggestion._highlightResult.code.value}</span>
                      </div>
                      <div class="col-xs-6 col-sm-4 col-md-4">
                          <span>Available Qty: ${suggestion.quantityAvailable.toLocaleString()}</span>
                      </div>
                  </div>
                  <div class="row hidden-xs">
                      <div class="col-sm-12 col-md-12 col-lg-12 col-xl-12">
                          <span>${suggestion.description}</span>
                      </div>
                  </div>
              </div>
          </div>`;

        return `<div class="algolia-result">${markup}</div>`;
      }
    }
  };
});

$('#aa-search-input').autocomplete({
    hint: true,
    debug: true,
    templates: {
         empty: `<div class="algolia-result"><span> No results were found with your current selection.</span></div>`
    }
  },
  sources
).on('autocomplete:selected', function(event, suggestion, dataset) {
  window.location.href = window.location.origin + '/' + suggestion.url
});

我这里有几件很酷的事情。

  1. 我正在遍历一个数组,该数组包含我要查询的索引的名称。这能够显着减少我打算根据 Algolia 的教程编写的冗余代码。
  2. 我在更多研究中发现,我可以在根 autocomplete() 函数中有一个“默认模板”作为一个选项。使用该默认模板就像向其添加“空”选项一样简单。此选项检查是否所有数据集都为空,然后在我的例子中显示一个简单的 div。

感谢这些作者让我找到了解决方案。

可以在这里找到一个正常工作的 fiddle :http://jsfiddle.net/jandk4014/rtkhw7o0/43/

关于javascript - 如何隐藏动态 div,除非所有 div 都有特定的类 - algolia,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51991716/

相关文章:

javascript - Twitter API JSON 调用未获取最新 3 条推文

javascript - jQuery Flot 折线图,x 轴为月份、年份

javascript - 是否可以根据您输入的内容进行文本输入和建议?

javascript - JavaScript 中多个数组的笛卡尔积

javascript - R Shiny DataTable 选定的行颜色

javascript - 尝试使用 gh-pages 部署我的 React 应用程序但收到此错误消息 : The "file" argument must be of type string. Received type undefined

php - 在 iFrame 中显示的 PDF 上绘制坐标

javascript - 在页面加载时更改 img src 值

php - 使用 PHP/HTML 链接在没有 jQuery 的情况下运行 SQL 查询?

html - Firefox 字体显示双层比较 chrome