Create a Dynamic Webpage
FormPage works in many ways like FormFunction, but it keeps the form above the result, so that you can keep interacting with it.
In[1]:=
data:image/s3,"s3://crabby-images/239a1/239a1e38df3fb406cdd36cfff3374cab4d24f0d2" alt="Click for copyable input"
CloudDeploy[
FormPage[{"n", "Please enter the number of sides"} ->
Restricted["Integer", {3, Infinity}],
Graphics[RegularPolygon[#n]] &]]
You can visit the page to interact with it: at first no result is shown.
data:image/s3,"s3://crabby-images/619bb/619bb30d4770ebda4dbab50e5b5f74e7c3b4d9b0" alt=""
Entering a number will update the page.
data:image/s3,"s3://crabby-images/f83ec/f83ecfc68f24d1b25eff6e8b9c174522f24a78cc" alt=""
You can improve the FormPage by changing the default controller and the placement of the elements. AutoSubmitting is also useful if you want the page to update whenever a field is changed.
In[2]:=
data:image/s3,"s3://crabby-images/438de/438de7bfdb9feb148e2b1fd3f0096f9e25a4d00a" alt="Click for copyable input"
CloudDeploy[
FormPage[{"n", "Please enter the number of sides"} ->
AutoSubmitting[<|"Interpreter" -> Restricted["Integer", {3, 20}],
"Control" -> Slider|>],
Graphics[RegularPolygon[#n]] &, {"Form"} -> {"Form", "Result",
"Form"}]]
Visit the resulting page.
data:image/s3,"s3://crabby-images/a6eba/a6eba30f41c8089dba874f23f3b304b9fff16edc" alt=""
data:image/s3,"s3://crabby-images/15862/158628332a38ff7a3d45b49cad22db264698073f" alt=""