你有几个选择.
这是一个快速的函数,我在jQuery中将它们组合在一起,可以完成你想要的任务.此选项要求客户端启用JavaScript才能工作.
如果您不想将JavaScript作为一项要求
如果你想要一个没有JavaScript的解决方案(客户端代码).您可能会放置一个输入框,其旁边的选择框与其后面的"名称"相同,并在您的选择框中添加"其他"选项.
<select name="selAnimals" id="selAnimals">
<option value="dog">Dog</option>
<option value="cat">Cat</option>
<option value="bird">Bird</option>
<option value="guineapig">Guinea Pig</option>
<option value="">Other</option>
</select>
<input type="text" name="selAnimals_Other" id="selAnimals_Other" />
Run Code Online (Sandbox Code Playgroud)
现在你的PHP必须同时检查$ _POST ["selAnimals"]和$ _POST ["selAnimals_Other"]以获得正确的值.
最好的选择是将上面的HTML和上面的JavaScript结合起来,为那些启用或禁用JavaScript的人创建一个优雅降级的解决方案.
我从答案的顶部向jsfiddle添加了额外的HTML INPUT标签,只更改了jQuery函数的1行(makeInputSelect).
var $inp = $("#" + id + "_Other");
Run Code Online (Sandbox Code Playgroud)