# 从搜索框给动作传递参数 # 简单传递 操作方式: - 输入动作关键词,找到动作后按Tab键选定动作 - 输入要传递给动作的参数,按回车运行动作。 ![普通搜索传递参数.gif](https://cdn.nlark.com/yuque/0/2021/gif/272392/1617462057710-9de82a3e-48c0-4271-b75a-d190e7bd13cd.gif#averageHue=%23f8f8f8&crop=0&crop=0&crop=1&crop=1&height=839&id=TxsWd&margin=%5Bobject%20Object%5D&name=%E6%99%AE%E9%80%9A%E6%90%9C%E7%B4%A2%E4%BC%A0%E9%80%92%E5%8F%82%E6%95%B0.gif&originHeight=839&originWidth=1637&originalType=binary&ratio=1&rotation=0&showTitle=false&size=370310&status=done&style=none&title=&width=1637)
在动作中: - 可以通过 `{quicker_in_param}` 变量读取输入的参数。 - 也可以在“获取选中的文本”模块中开启“如果为动作传递了参数,使用参数值作为获取的结果”选项,使动作既可以使用普通操作方式(选中文本后运行动作),也可以直接在搜索框里输入要操作的文本。 # 实时搜索 _以下内容基于版本1.25.0。_
在搜索框输入内容时调用动作并传入参数 `search:搜索词` 。根据动作返回的内容生成结果条目。
[示例动作](https://getquicker.net/sharedaction?code=98b9522b-b97e-48ed-afd8-08d8f6743496)
![实时搜索.gif](https://cdn.nlark.com/yuque/0/2021/gif/272392/1617461658095-efb74294-d537-4a4f-968b-a1373b63475f.gif#averageHue=%23fefefe&crop=0&crop=0&crop=1&crop=1&height=1337&id=m2qOp&margin=%5Bobject%20Object%5D&name=%E5%AE%9E%E6%97%B6%E6%90%9C%E7%B4%A2.gif&originHeight=1337&originWidth=1637&originalType=binary&ratio=1&rotation=0&showTitle=false&size=245605&status=done&style=none&title=&width=1637) ## 实现步骤 ### 1)在动作中开启支持实时搜索的选项。 ![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1617462545769-c4bda92c-c77b-4288-873e-ac9977e6810a.png#averageHue=%23f8f5f5&crop=0&crop=0&crop=1&crop=1&height=323&id=pPVXU&margin=%5Bobject%20Object%5D&name=image.png&originHeight=645&originWidth=449&originalType=binary&ratio=1&rotation=0&showTitle=false&size=39877&status=done&style=none&title=&width=224.5) ### 2)判断如果是否为搜索框传入的参数 如果是实时搜索传参,则对搜索内容进行处理并返回结果。
表达式:`**$=** **{quicker_in_param}**.**StartsWith**("search:")`    
![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1617462620751-a795eff2-2965-4f4e-8f36-0aeea6b5ffb0.png#averageHue=%23fbfbfb&crop=0&crop=0&crop=1&crop=1&height=331&id=eauSS&margin=%5Bobject%20Object%5D&name=image.png&originHeight=662&originWidth=1180&originalType=binary&ratio=1&rotation=0&showTitle=false&size=41648&status=done&style=none&title=&width=590)
![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1617462654093-dc02f765-9558-4e77-8836-aff26559b1c7.png#averageHue=%23f8f7f6&crop=0&crop=0&crop=1&crop=1&height=119&id=INgQy&margin=%5Bobject%20Object%5D&name=image.png&originHeight=237&originWidth=756&originalType=binary&ratio=1&rotation=0&showTitle=false&size=20893&status=done&style=none&title=&width=378) ### 3) 返回搜索结果数据 目前支持两种格式的返回数据:多行文本格式、JSON数据格式。 #### A. 多行文本格式 ![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1624974749619-92efca80-7874-4893-b37f-55292ba6157a.png#averageHue=%23fcfaf9&clientId=ua67179df-c33c-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=236&id=ub2b5914a&margin=%5Bobject%20Object%5D&name=image.png&originHeight=471&originWidth=2119&originalType=binary&ratio=2&rotation=0&showTitle=false&size=174059&status=done&style=none&taskId=ufe7af957-bdf4-4825-83a9-61970b49577&title=&width=1059.5)
每行输出一个结果选项。
`[图标]文字(描述文字)|operation=选择选项后的操作&data=要操作的值的URL编码`  - 图标格式与“用户选择”“文本窗口菜单”等位置一样。 - |后面的内容需要是合法的querystring,因此data数据通常需要进行url编码。 - operation表示选择选项后执行的操作类型。 - data:结果数据的内容。 - datatype:可选,指定data数据的内容类型。可选值为`path`、`text`、`custom`。 - 值为`path`时,Quicker会自动给搜索结果项添加右键菜单:
![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1624974328289-203e7dfb-065d-46a6-b29a-7f1eb3d31e69.png#averageHue=%23f4f4f4&clientId=ua67179df-c33c-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=216&id=ubb6ec04d&margin=%5Bobject%20Object%5D&name=image.png&originHeight=432&originWidth=1075&originalType=binary&ratio=2&rotation=0&showTitle=false&size=67023&status=done&style=none&taskId=u41c27384-a87b-446e-b65b-a74c5e2e6a3&title=&width=537.5) - 类型为`text`时,会自动添加文本内容上下文菜单。 - 类型为 `custom`时,不会自动添加菜单项。(需版本1.36.7+) - menu:可选,URL编码后的自定义菜单项数据。格式与动作右键菜单相同。点击右键菜单时,将使用` menu:菜单项的值:结果项data` 作为参数调用动作。
![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1624975106026-5cd809ef-1238-4924-90f1-b607afb006f3.png#averageHue=%23f4f4f4&clientId=ua67179df-c33c-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=127&id=u7a8bdf14&margin=%5Bobject%20Object%5D&name=image.png&originHeight=253&originWidth=649&originalType=binary&ratio=2&rotation=0&showTitle=false&size=22243&status=done&style=none&taskId=u365dd39f-b846-4f04-b068-cd0d71620a7&title=&width=324.5) #### B. JSON数据格式 返回数据为C#对象`CustomSearchResult`的JSON序列化。类的定义请参考这里的代码:[https://gist.github.com/cuiliang/8475a0b5420a78bfff52c8030450329a](https://gist.github.com/cuiliang/8475a0b5420a78bfff52c8030450329a) CommonOperationItem 类将作为一个通用类用于更多场景的数据传输。
在这里,它的Children属性用于存储结果项的右键菜单。 ```json { "Items": [ { "Score": 80, // 批量程度 "NoHide": false, // 选择选项后是否自动隐藏搜索框。 仅在结果项用于继续触发搜索框时使用,以避免搜索框闪烁。 "Title": "结果项标题", "Description": "结果项描述", "Icon": "fa:Light_Cog", // 主图标 "SecondaryIcon": "fa:Solid_History", // 角标 "Data": "内容数据", "DataType": "text", "Operation": null, // 无意义 "Action": null, // 无意义 "IsSeparator": false, // 无意义 "ExtraData": null, // 用于传递额外数据的词典 "Children": [ // 子项数据,这里用于存储额外的右键菜单项 { "Icon": "fa:Light_Cog", //菜单图标 "Title": "菜单项1", // 菜单标题 "Data": "settings", // 菜单KEY "Description": "tooltip", // 菜单提示 "DataType": null, "Operation": null, "Action": null, "IsSeparator": false, // 是否为分割线 "ExtraData": null, "Children": null } ] }, ... ] } ``` 也可通过表达式直接返回CustomSearchResult类型的对象: ```csharp $=new CustomSearchResult(){ Items = new List(){ new CustomSearchResultItem(){ Title = "结果项标题", Icon = "fa:Light_Cog", SecondaryIcon = "fa:Light_history", DataType = "text", Data = "Hello World", //.....其他属性,可以通过补全查看... } }}; ``` ## 通过面板或快捷键触发动作时进入搜索模式 如果动作的主要功能为实时搜索,可能会希望通过快捷键直接启动搜索框并使用这个动作开始搜索。
可以在动作中增加“Quicker操作”模块,类型选择“使用当前动作进行实时搜索”操作类型。
![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1617764706435-b9d1b7f2-931e-47e0-8da8-34a7a17325fa.png#averageHue=%23fbfbfb&crop=0&crop=0&crop=1&crop=1&height=300&id=OKxeQ&margin=%5Bobject%20Object%5D&name=image.png&originHeight=599&originWidth=1180&originalType=binary&ratio=1&rotation=0&showTitle=false&size=36800&status=done&style=none&title=&width=590)
在动作中可以使用这样的判断过程: - 如果动作参数以 `search:` 开始,表示正在搜索框中进行实时搜索。此时处理搜索内容并返回结果即可。 - 如果动作参数为空,表示是通过其他方式启动动作,可以使用上述模块开启搜索模式。 ![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1617764901140-d6b17d47-36fd-4912-b3a5-3b990b7a6cbb.png#averageHue=%23f8f7f7&crop=0&crop=0&crop=1&crop=1&height=133&id=ptoUd&margin=%5Bobject%20Object%5D&name=image.png&originHeight=265&originWidth=1028&originalType=binary&ratio=1&rotation=0&showTitle=false&size=27034&status=done&style=none&title=&width=514) ## 如何调试实时搜索 可以另外创建一个组合动作,在其中使用“运行或停止其它动作”模块。
![image.png](https://cdn.nlark.com/yuque/0/2021/png/272392/1628476625204-8970a7b1-a3db-49a3-a1d8-42517052031e.png#averageHue=%23fcfcfc&clientId=ua799ee64-50fc-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=587&id=u6cf18437&margin=%5Bobject%20Object%5D&name=image.png&originHeight=1173&originWidth=1255&originalType=binary&ratio=1&rotation=0&showTitle=false&size=107760&status=done&style=none&taskId=ub0b403a3-c05b-420e-af86-c14df377881&title=&width=627.5) # 更新历史 - 20221116:datatype增加`custom`类型(v1.36.7)。