Posts Tagged ‘html’
I am not a big fan of using checkboxes for a simple yes/no question on a form. I use checkboxes only for selecting multiple items to perform an action on, or when I am using a checkboxlist. The reason for this is because I believe a yes/no question has three possible states, not only two.
If you are asking a user “Do you agree with our terms?”, the general consensus is to assume that not clicking the box is “forgetting” to make a selection and warning me that “You have forgotten to tick our terms and conditions”. In this situation the case may be so, but what if I did not agree? What if the question was “Do you want to opt out of us sending you loads and loads of spam?” and simply not spotting this question.
I believe that if you did not make a selection it is a valid state. Thus a yes/no question, in my opinion, has the following states; “yes”, “no” and “did not choose”.
Once again, I don’t simply rant, I also offer a solution… a very simple extension method which I love using for all my yes/no questions instead of checkboxes. In this case I made the “not selected” state 0.
public static string YesNoDropDownList(this HtmlHelper helper, string id, string selectedValue)
{
var list = new SelectList(new[]
{
new {text = "Select", value = "0"},
new {text = "No", value = "1"},
new {text = "Yes", value = "2"}
}, "value", "text", selectedValue);
return helper.DropDownList(id, list);
}
PS: It also looks a bit neater and more uniform.
The easiest way to split your unordered list into columns is by assigning css classes.
<ul> <li class="left">Item 1</li> <li class="left">Item 2</li> <li class="right_first">Item 3</li> <li class="right">Item 4</li> </ul>
.left {
margin-left: 0px;
}
.right {
margin-left: 50%;
}
.right_first {
margin-top: -40px;
}
If you know the size of the list then you can play around with the top margin of the “right_first” class. In our case, we do not know the size of the list, so we would have to do some black magic…
// First we calculate some variables
// the minimum column length (items / 2) at which to split into columns
var columnSplitLength = 7;
// the current would be column length
var currentColumnLength = Math.round(items.length / 2);
// is the items an odd or even length
var isOdd = (items.length > 2) != currentColumnLength;
// should we split the columns?
var shouldSplitColumns = currentColumnLength > columnSplitLength;
var count = 1; var myLiHeight = 13; // height of each ListItem
$.each(items, function() {
var className = shouldSplitColumns && (count > currentColumnLength) ? "right":"left";
if(count == currentColumnLength+1)
className = "right_first";
var resultRow = $.stringFormat("<li class='{0}'>{1}</li>", [className, this.name]);
$(resultRow).appendTo("#myUlList");
count++;
});
// If the list length is odd, we have to add a phantom item to the right to balance
if(isOdd) {
$("<li class='right'></li>").appendTo("#myUlList");
count++;
}
// Lastly, reset the first item of the right column to the top
$(".right_first").css("margin-left", "50%");
$(".right_first").css("margin-top", "-"+count*myLiHeight+"px");