Multiple ways to change the SELECT options in an HTML drop-down box

Multiple ways to change the SELECT options in an HTML drop-down box
After the form is submitted, the returned HTML page is re-rendered, and neither the value nor the selectedIndex attribute of the SELECT control can make the drop-down box retain the state before the form is submitted.

Copy code
The code is as follows:

<SELECT id="idState" style="width:150" name="state" selectedIndex="$!{state}">
<OPTION value="">All</OPTION>
<OPTION value="1">Pass</OPTION>
<OPTION value="2">Not passed</OPTION>
<OPTION value="3">Pending</OPTION>
</SELECT>

A temporary solution is to add a script at the end of the vm file to assign a value to the drop-down box :

Copy code
The code is as follows:

<script>
$('#idState').val('$!{state}');
</script>

Another solution is to set a default selection :

Copy code
The code is as follows:

<SELECT id="idState" style="width:150" name="state" value="$!{state}">
<OPTION value="">All</OPTION>
<OPTION value="1">Pass</OPTION>
<OPTION value="2" SELECTED>Not passed</OPTION>
<OPTION value="3">Pending</OPTION>
</SELECT>

The VTL way of writing is :

Copy code
The code is as follows:

<SELECT id="idState" style="width:150" name="state" value="$!{state}">
<OPTION value="">All</OPTION>
<OPTION #if($!{state} == 1) SELECTED #end value="1">Pass</OPTION>
<OPTION #if($!{state} == 2) SELECTED #end value="2">Not passed</OPTION>
<OPTION #if($!{state} == 3) SELECTED #end value="3">To be processed</OPTION>
</SELECT>

It should be noted here that when performing == comparison, Velocity distinguishes between types. If you compare with the strings "1", "2", and "3", you will always get false.
Comparison issues in velocity <br />For velocity, comparisons, especially those involving inequality comparisons (greater than or less than), are difficult to implement. Now I want to display the file size on the page in categories (Bytes, MB, GB), which involves the problem of comparing filesize sizes. Is there a better way to achieve this?
For example, the following code:

Copy code
The code is as follows:

#if ($filesize > 1024 && $filesize < 1048567)
#set($ksize = $filesize%1024)
<div class="mlt">File Size: $ksize KB
#elseif ($filesize > 1048567 && $filesize < 1073731824)
#set($msize=$filesize%1048567)
<div class="mlt">File Size: $msize MB
#elseif ($filesize > 1073731824)
#($gsize=$filesize%1073731824)
<div class="mlt">File Size: $gsize GB
#else
<div class="mlt">File Size: $filesize Bytes
#end


Copy code
The code is as follows:

<PRE class=html name="code"><SPAN style="FONT-FAMILY: Arial, Helvetica, sans-serif"><SPAN style="WHITE-SPACE: normal">
</SPAN></SPAN></PRE>
<PRE></PRE>
<PRE></PRE>
<PRE></PRE>

<<:  Pagination Examples and Good Practices

>>:  How to successfully retrieve VMware Esxi root password after forgetting it

Recommend

MySQL 5.7.17 winx64 installation and configuration graphic tutorial

I summarized the previous notes on installing MyS...

Vue.js application performance optimization analysis + solution

Table of contents 1. Introduction 2. Why do we ne...

Docker modifies the configuration information of an unstarted container

When I first used docker, I didn't use docker...

How to forget the root password in Mysql8.0.13 under Windows 10 system

1. First stop the mysql service As an administrat...

How to create and run a Django project in Ubuntu 16.04 under Python 3

Step 1: Create a Django project Open the terminal...

Detailed explanation of Django+Vue+Docker to build an interface testing platform

1. Two words at the beginning Hello everyone, my ...

Super detailed basic JavaScript syntax rules

Table of contents 01 JavaScript (abbreviated as: ...

Overview and differences between html inline elements and html block-level elements

Block-level element features : •Always occupies a ...

MySQL prepare principle detailed explanation

Benefits of Prepare The reason why Prepare SQL is...

CSS sample code to achieve circular gradient progress bar effect

Implementation ideas The outermost is a big circl...

The Complete Guide to Grid Layout in CSS

Grid is a two-dimensional grid layout system. Wit...

Solution to mysql failure to start due to insufficient disk space in ubuntu

Preface Recently, I added two fields to a table i...