Click here to Skip to main content
15,891,905 members
Please Sign up or sign in to vote.
0.00/5 (No votes)
See more:
How to set hh:mm in textbox., show current time in textbox like
10:45 so user can edit time 11:48, semicolon should not edit.,
Posted
Comments
Andrewpeter 22-Sep-12 1:57am    
Only edit hours and seconds? Not edit miliseconds?

For HH:mm format in Textbox you have to mask the textbox


C#
<pre lang="HTML">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Untitled Page</title>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="jquery.maskedinput.js"></script>
</head>
<body>
<form id="form1" runat="server">

<asp:textbox runat="server" id="txt1" text="99:99" xmlns:asp="#unknown">

</form>
</body>
<script type="text/javascript">
$(function () {

$("#txt1").mask("99:99");
});
</script>
</html>



////////////////////////
Attach Jquery.js and jquery.maskedinput.js to your page
This is jquery.maskedinput.js
/////////////////////


/*
* Copyright (c) 2007 Josh Bush (digitalbush.com)
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:

* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/

/*
* Version: RC3
* Release: 2007-07-01
*/
(function ($) {
//Helper Functions for Caret positioning
getCaretPosition = function (ctl) {
var res = { begin: 0, end: 0 };
if (ctl.setSelectionRange) {
res.begin = ctl.selectionStart;
res.end = ctl.selectionEnd;
} else if (document.selection && document.selection.createRange) {
var range = document.selection.createRange();
res.begin = 0 - range.duplicate().moveStart('character', -100000);
res.end = res.begin + range.text.length;
}
return res;
}

setCaretPosition = function (ctl, pos) {
if (ctl.setSelectionRange) {
ctl.focus();
ctl.setSelectionRange(pos, pos);
} else if (ctl.createTextRange) {
var range = ctl.createTextRange();
range.collapse(true);
range.moveEnd('character', pos);
range.moveStart('character', pos);
range.select();
}
}

//Predefined character definitions
var charMap = {
'9': "[0-9]",
'a': "[A-Za-z]",
'*': "[A-Za-z0-9]"
};

//Helper method to inject character definitions
$.mask = {
addPlaceholder: function (c, r) {
charMap[c] = r;
}
};

//Main Method
$.fn.mask = function (mask, settings) {
settings = $.extend({
placeholder: "_",
completed: null
}, settings);

//Build Regex for format validation
var reString = "^";
for (var i = 0; i < mask.length; i++)
reString += (charMap[mask.charAt(i)] || ("\\" + mask.charAt(i)));
reString += "$";
var re = new RegExp(reString);

return this.each(function () {
var input = $(this);
var buffer = new Array(mask.length);
var locked = new Array(mask.length);

//Build buffer layout from mask
for (var i = 0; i < mask.length; i++) {
locked[i] = charMap[mask.charAt(i)] == null;
buffer[i] = locked[i] ? mask.charAt(i) : settings.placeholder;
}

/*Event Bindings*/
input.focus(function () {
checkVal();
writeBuffer();
setCaretPosition(this, 0);
});

input.blur(checkVal);

//Paste events for IE and Mozilla thanks to Kristinn Sigmundsson
if ($.browser.msie)
this.onpaste = function () { setTimeout(checkVal, 0); };
else if ($.browser.mozilla)
this.addEventListener('input', checkVal, false);

var ignore = false; //Variable for ignoring control keys

input.keydown(function (e) {
var pos = getCaretPosition(this);
var k = e.keyCode;
ignore = (k < 16 || (k > 16 && k < 32) || (k > 32 && k < 41));

//delete selection before proceeding
if ((pos.begin - pos.end) != 0 && (!ignore || k == 8 || k == 46)) {
clearBuffer(pos.begin, pos.end);
}
//backspace and delete get special treatment
if (k == 8) {//backspace
while (pos.begin-- >= 0) {
if (!locked[pos.begin]) {
buffer[pos.begin] = settings.placeholder;
if ($.browser.opera) {
//Opera won't let you cancel the backspace, so we'll let it backspace over a dummy character.
writeBuffer(pos.begin);
setCaretPosition(this, pos.begin + 1);
} else {
writeBuffer();
setCaretPosition(this, pos.begin);
}
return false;
}
}
} else if (k == 46) {//delete
clearBuffer(pos.begin, pos.begin + 1);
writeBuffer();
setCaretPosition(this, pos.begin);
return false;
} else if (k == 27) {
clearBuffer(0, mask.length);
writeBuffer();
setCaretPosition(this, 0);
return false;
}

});

input.keypress(function (e) {
if (ignore) {
ignore = false;
return;
}
e = e || window.event;
var k = e.charCode || e.keyCode || e.which;

var pos = getCaretPosition(this);
var caretPos = pos.begin;

if (e.ctrlKey || e.altKey) {//Ignore
return true;
} else if ((k >= 41 && k <= 122) || k == 32 || k > 186) {//typeable characters
while (pos.begin < mask.length) {
var reString = charMap[mask.charAt(pos.begin)];
var match;
if (reString) {
var reChar = new RegExp(reString);
match = String.fromCharCode(k).match(reChar);
} else {//we're on a mask char, go forward and try again
pos.begin += 1;
pos.end = pos.begin;
caretPos += 1;
continue;
}

if (match)
buffer[pos.begin] = String.fromCharCode(k);
else
return false; //reject char

while (++caretPos < mask.length) {//seek forward to next typable position
if (!locked[caretPos])
break;
}
break;
}
} else
return false;

writeBuffer();
if (settings.completed && caretPos >= buffer.length)
settings.completed.call(input);
else
setCaretPosition(this, caretPos);

return false;
});

/*Helper Methods*/
function clearBuffer(start, end) {
for (var i = start; i < end; i++) {
if (!locked[i])
buffer[i] = settings.placeholder;
}
}

function writeBuffer(pos) {
var s = "";
for (var i = 0; i < mask.length; i++) {
s += buffer[i];
if (i == pos)
s += settings.placeholder;
}
input.val(s);
return s;
}

function checkVal() {
//try to place charcters where they belong
var test = input.val();
var pos = 0;
for (var i = 0; i < mask.length; i++) {
if (!locked[i]) {
while (pos++ < test.length) {
//Regex Test each char here.
var reChar = new RegExp(charMap[mask.charAt(i)]);
if (test.charAt(pos - 1).match(reChar)) {
buffer[i] = test.charAt(pos - 1);
break;
}
}
}
}
var s = writeBuffer();
if (!s.match(re)) {
input.val("");
clearBuffer(0, mask.length);
}
}
});
};
})(jQuery);
 
Share this answer
 
C#
TextBox1.Text=DateTime.Now.ToString("HH:mm");


Have fun!
 
Share this answer
 
Comments
Umapathi K 22-Sep-12 2:04am    
here semicolon in edit mode., user should not erase that.
amirmohamad 22-Sep-12 2:50am    
if you want user can't edit this use this code in label
User cant edit content of TextBox - you can set ReadOnly property of TextBox to True. You try!
 
Share this answer
 
Is it a normal textbox?
Are you specifically using it for Date Time purpose?
 
Share this answer
 
Comments
Umapathi K 22-Sep-12 2:03am    
need to show only time

This content, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)



CodeProject, 20 Bay Street, 11th Floor Toronto, Ontario, Canada M5J 2N8 +1 (416) 849-8900