Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Disable autocomplete on html helper textbox in MVC

Ok,

I would in normal asp.net use a theme to turn off autocomplete on all text boxes on an entire site. However i cannot do this on MVC because nothing in the theme .skin files seems to work.

I have this in my .skin file:

<asp:TextBox runat="server" autocomplete="off" />

however this does not render at all, of course because this is not how MVC works. Anyway is there any way i can get this sort of thing to work. The site i am trying to do it on is too big to warrant changing every textbox or creating a new HTML helper to solve the issue?

Anyone got any ideas?

like image 282
Giles Papworth Avatar asked Mar 11 '11 14:03

Giles Papworth


Video Answer


3 Answers

Cheers for the answers guys, however those solutions would really require me to edit all the forms in the site, if you saw the use of MVC we are doing, you would understand.

Anyway i opted for this way, in the master page i added this script:

<script language="javascript" type="text/javascript">
        $(document).ready(function () {
            try {
                $("input[type='text']").each(function(){
                               $(this).attr("autocomplete","off");
                            });
            }
            catch (e)
            { }
        });

    </script>

I know if javascript is disabled this is worthless however to be honest if javascript is disabled the users won't be able to use half the site.

like image 176
Giles Papworth Avatar answered Sep 18 '22 10:09

Giles Papworth


Instead of off- write anything @autocomplete='write-anything-instead-of-off'

@Html.TextBoxFor(model => model.FirstName, new { placeholder = "First Name", @class = "form-control", @id = "txtFirstName", @autocomplete = "new-FirstName"})
like image 29
Piku Shrivastav Avatar answered Sep 21 '22 10:09

Piku Shrivastav


MVC does not have server controls like plain old ASP.NET. Therefore no server processing is done on your controls. They are rendered to the client exactly how you type them. Themes are not something you will use in MVC, because they apply to ASP.NET server controls and you won't be using those here. That said, HTML helpers do get processed by the server as the view is rendered. You will need to add autocomplete="off" to the actual HTML control using the html properties overload.

@Html.TextBoxFor(x => x.Something, new { autocomplete="off" } )

Or whatever the actual HTML attribute is that gets rendered when you set autocomplete="off" in the asp.net server control.

EDIT: One option to affect all text boxes would be to create your own Html helper method. Just create an extension method Like this:

using System.Web.Mvc;
using System.Web.Mvc.Html;

public static MvcHtmlString NoAutoCompleteTextBoxFor<TModel, TValue>(this HtmlHelper<TModel> html, Expression<Func<TModel, TValue>> expression)
{
    return html.TextBoxFor(expression, new { autocomplete="off" });
}

Then you can just do:

Html.NoAutoCompleteTextBoxFor(x => x.Something)
like image 44
Chev Avatar answered Sep 18 '22 10:09

Chev