gpt4 book ai didi

html - 希望在提交和页面重新加载后保留选定的 html 选项

转载 作者:行者123 更新时间:2023-11-28 01:45:54 24 4
gpt4 key购买 nike

所以我看过一些类似的帖子,但我找不到任何关于 Rails 的帖子。我的问题类似于:Keep a Select Box Selected after Submit对于我想做的事情,答案是可以的,除了是 PHP。

我想要做的就是在用户选择过滤器选项并重新加载后,最后选择的选项保持选中状态,而不是转到默认值,这就是目前的所有选项。我正在使用 Rails,并且我有 Ajax 和 jQuery 作为可行的选项来执行此操作。现在页面重新加载和过滤所有工作,但我只希望所选选项在重新加载后保持选中状态。一开始我只想用 Ajax 重新加载我的表格的一部分,但我认为这超出了我的理解范围。

我的选项表(是的,我知道它很乱,我是网络应用程序的新手,所以如果有任何不相关的建议,我会打开):

<html>
<table class= "table table-bordered"%>
<thead>
<tr>
<th>Status:</th>
<th>Clec ID:</th>
<th>Task ID:</th>
<th>Task Type:</th>
<th>Hostname:</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<form action="/task_queues" method="GET">
<td>
<select name="by_status">
<option value="">All</option>
<option value="Completed">Completed</option>
<option value="Pending">Pending</option>
<option value="Failed">Failed</option>
</select>
</td>
<td>
<select name="by_clecid">
<option value="">All</option>
<% @clecids.each do |clecid| %><option value="<%= clecid %>"><%= clecid %></option><% end %>
</select>
</td>
<td>
<select name="by_taskid">
<option value="">All</option>
<% @taskids.each do |taskid| %><option value="<%= taskid %>"><%= taskid %></option><% end %>
</select>
</td>
<td>
<select name="by_tasktype">
<option value="">All</option>
<% @tasktypes.each do |tasktype| %><option value="<%= tasktype %>"><%= tasktype %></option><% end %>
</select>
</td>
<td>
<select name="by_hostname">
<option value="">All</option>
<% @hostnames.each do |hostname| %><option value="<%= hostname %>"><%= hostname %></option><% end %>
</select>
</td>
<td><input type="submit"/>
</td>
</form>
</tr>
</tbody>
</table>

PHP 答案:(我也不关心这个,因为他会生成选项)。

<select name="test">
<?php
$options = array(1 => 'Option 1', 2 => 'Option 2', 3 => 'Option 3');
foreach ($options as $key => $value) {
echo '<option value="' . $key . '"' . ($key == $_GET["test"] ? ' selected="selected"' : '') . '>' . $value . '</option>';
} ?>
</select>

我也怀疑你们需要看到这个,但这里有一些 Controller 希望能让你们理解我的困惑:

class TaskQueuesController < ApplicationController
before_action :set_task_queue, only: [:show, :edit, :update, :destroy]
has_scope :by_status, :by_tasktype, :by_taskid, :by_hostname, :by_clecid

def index
@task_queues = apply_scopes(TaskQueue).all
@task_queues = @task_queues.paginate(:page => params[:page], :per_page => 30)
@clecids = TaskQueue.uniq.pluck(:clecid).sort
@taskids = TaskQueue.uniq.pluck(:taskid).sort
@tasktypes = TaskQueue.uniq.pluck(:tasktype).sort
@hostnames = TaskQueue.uniq.pluck(:hostname).reject!(&:blank?)
end

如有任何帮助,我们将不胜感激!

最佳答案

普雷斯顿根据您的代码我添加了 Rails 代码。

<html>
<table class= "table table-bordered"%>
<thead>
<tr>
<th>Status:</th>
<th>Clec ID:</th>
<th>Task ID:</th>
<th>Task Type:</th>
<th>Hostname:</th>
</tr>
</thead>
<tbody>
<tr>
<form action="/task_queues" method="GET">
<td>
<select name="by_status">
<option value="">All</option>
<option value="Completed">Completed</option>
<option value="Pending">Pending</option>
<option value="Failed">Failed</option>
</select>
</td>
<td>
<%= select_tag "by_clecid","<option value=\"0\">All</option>"+options_for_select(@clecids.collect {|t| [t.clecid.to_s,t.clecid]}, params[:by_clecid] ) %>
</td>
<td>
<%= select_tag "by_taskid","<option value=\"0\">All</option>"+options_for_select(@taskids.collect {|t| [t.taskid.to_s,t.taskid]}, params[:by_taskid] ) %>
</td>
<td>
<%= select_tag "by_tasktype","<option value=\"0\">All</option>"+options_for_select(@tasktypes.collect {|t| [t.tasktype.to_s,t.tasktype]}, params[:by_tasktype] ) %>
</td>
<td>
<%= select_tag "by_hostname","<option value=\"0\">All</option>"+options_for_select(@hostnames.collect {|t| [t.hostname.to_s,t.hostname]}, params[:by_hostname] ) %>
</td>
<td> <input type="submit"/></td>
</form>
</tr>
</tbody>
</table>

好吧,我建议你看看这个例子并在你的组合框中写下值,因为我不知道你想传递什么字符串或整数。

 http://jsfiddle.net/ashwyn/yL6w3/1/

如果代码不起作用,请在我发送给您的链接上写下您想要的真实值

关于html - 希望在提交和页面重新加载后保留选定的 html 选项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22715122/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com