使用Google Apps脚本搜索电子表格不会返回任何数据

问题描述 投票:1回答:1

我想在电子表格中搜索数据并将结果显示在HTML网页上。

我的问题:网页上没有显示结果。

我的策略:

  1. 数据库以电子表格形式保存在Google云端硬盘中。
  2. 网页访问者在文本框中输入字符串,然后单击搜索按钮。
  3. Column A中搜索字符串并返回同一行的数据。
  4. 将行的结果数据放在网页(同一页面)中。
function doGet() {
 return HtmlService.createTemplateFromFile('index').evaluate();
  var searchString = document.getElementById('searchString').value;
} 

function onOpen() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var menuEntries = [ {name: "Search", functionName: "onSearch"} ];
  ss.addMenu("Commands", menuEntries);    
}

function onSearch() {
    var searchString = function doGet() {
                       document.getElementById('searchString').value;
                       }
    var sheetActive = SpreadsheetApp.openById("1MQVrQ7fmkitP-KNvv9m17Yi0ykGWgF5UjrVh5yCP8RE");
    var sheet = sheetActive.getSheetByName("Sheet1");

    var column =1; //column Index   
    var columnValues = sheet.getRange(2, column, sheet.getLastRow()).getValues(); //1st is header row
    var searchResult = columnValues.findIndex(searchString); //Row Index - 2

    if(searchResult != -1)
    {
        //searchResult + 2 is row index.
        SpreadsheetApp.getActiveSpreadsheet().setActiveRange(sheet.getRange(searchResult + 2, 1));
         document.getElementById("searchResult").innerHTML = searchResult;

    }
 }

Array.prototype.findIndex = function(search){
  if(search == "") return false;
  for (var i=0; i<this.length; i++)
    if (this[i] == search) return i;

  return -1;
}
<!DOCTYPE html>
<html>
  <head>
    <base target="_top">
  </head>

<body>
<input type="text" id="searchString" name="searchString" />

    <script>
      google.script.run.doGet();
      google.script.run.onOpen();
    </script>

<a href="javascript: onSearch();">Search</a>
<div id="searchResult"></div>
</body>
</html>
javascript html google-apps-script google-sheets
1个回答
0
投票

我认为这是一个错字问题:你添加了一个字符串:document.getElementById("searchResult").innerHTML = "searchResult";

并且可能必须用您的变量替换它:

document.getElementById("searchResult").innerHTML = searchResult;
© www.soinside.com 2019 - 2024. All rights reserved.