如果你想实现在按下提交按钮之外,通过键盘回车也能触发提交的功能,你可以使用Streamlit的`st.text_input`方法结合`st.form_submit_button`方法来实现。 首先,你可以使用`st.text_input`方法创建一个文本输入框,并将用户输入的文本赋值给一个变量,比如`user_input`: ```python user_input = st.text_input("请输入文本", key="user_input") ``` 然后,你可以使用`st.form_submit_button`方法创建一个表单提交按钮,并在按钮按下时触发提交操作: ```python if st.form_submit_button(label="提交") or st.session_state.get("enter_pressed"): with st.spinner("容我三思......🖥️"): # 进行提交操作 st.session_state["state"] = predict(user_input, 4096, 1.0, 1.0, st.session_state["state"]) ``` 在上面的代码中,我们使用了一个`enter_pressed`的session_state变量来表示是否按下了回车键。接下来,我们需要在Streamlit应用程序中添加一个事件监听器来捕获回车键按下事件,并将`enter_pressed`设置为True: ```python if st.session_state.get("enter_pressed") is None: st.session_state["enter_pressed"] = False # 添加事件监听器 if user_input: js_code = f""" <script> document.getElementById("{user_input.key}").addEventListener("keydown", function(event) {{ if (event.key === "Enter") {{ event.preventDefault(); streamlit.setComponentValue("{user_input.key}", true); }} }}); </script> """ st.components.v1.html(js_code) # 将enter_pressed设置为True if st.session_state.get("enter_pressed"): st.session_state["enter_pressed"] = False ``` 通过上述代码,当用户在文本输入框中按下回车键时,JavaScript代码会触发一个事件,在Streamlit应用程序中将`enter_pressed`设置为True。 这样,无论是点击提交按钮还是按下回车键,都可以触发提交操作。 希望这能帮助到你!如果你有任何其他问题,请随时提问。