it-swarm.com.ru

Как изменить текст кнопки в jQuery?

Как изменить текстовое значение кнопки в jQuery? В настоящее время моя кнопка имеет «Добавить» в качестве текстового значения, и после нажатия я хочу, чтобы она изменилась на «Сохранить». Я попробовал этот метод ниже, но пока безуспешно:

$("#btnAddProfile").attr('value', 'Save');
460
user517406

Зависит от того, какой тип кнопки вы используете

<input type='button' value='Add' id='btnAddProfile'>
$("#btnAddProfile").attr('value', 'Save'); //versions older than 1.6

<input type='button' value='Add' id='btnAddProfile'>
$("#btnAddProfile").prop('value', 'Save'); //versions newer than 1.6

<!-- Different button types-->

<button id='btnAddProfile' type='button'>Add</button>
$("#btnAddProfile").html('Save');

Ваша кнопка также может быть ссылкой. Вам нужно будет опубликовать HTML для более конкретного ответа. 

EDIT: они будут работать, если вы, конечно, завернули его в вызов .click()

EDIT 2: более новые версии jQuery (от> 1.6) используют .prop вместо .attr

EDIT 3: если вы используете jQuery UI, вам нужно использовать метод DaveUK ( ниже ) для настройки свойства текста 

770
JohnP

Для кнопок, созданных с помощью .Button () в jQuery ........

В то время как другие ответы изменят текст, они испортят стилизацию кнопки, оказывается, что когда рендерится кнопка jQuery, текст кнопки вкладывается в промежуток, например.

<button id="thebutton">
  <span class="ui-button-text">My Text</span>
</button>

Если вы удалите диапазон и замените его текстом (как в других примерах) - вы потеряете диапазон и соответствующее форматирование.

Таким образом, вам действительно нужно изменить текст внутри тега SPAN, а НЕ КНОПКУ!

$("#thebutton span").text("My NEW Text");

или (если, как и я, это делается на событии клика)

$("span", this).text("My NEW Text");
132
DaveUK

Правильный способ изменить текст кнопки, если она была «застегнута» с помощью JQuery, - это использовать метод .button ():

$( ".selector" ).button( "option", "label", "new text" );
77
Sergey

Чтобы изменить текст кнопки, просто выполните следующую строку jQuery For

<input type='button' value='XYZ' id='btnAddProfile'>

использование

$("#btnAddProfile").val('Save');

в то время как для

<button id='btnAddProfile'>XYZ</button>

использовать этот

$("#btnAddProfile").html('Save');

33
Sangeet Menon

Используйте .val()

Вот ссылка на JSfiddle

32
rsplak

Вам нужно сделать .button("refresh")

HTML:

<button id='btnviewdetails' type='button'>SET</button>

JS:

$('#btnviewdetails').text('Save').button("refresh");
18
user1464277

Если вы нажали кнопку, это работает:

<button id="button">First caption</button>

$('#button').button();//make it Nice
var text="new caption";
$('#button').children().first().html(text);
12
Gluip

$("#btnAddProfile").text("Save");

9
i_emmanuel

Вы можете использовать что-то вроде этого:

$('#your-button').text('New Value');

Вы также можете добавить дополнительные свойства, как это:

$(this).text('New Value').attr('disabled', true).addClass('bt-hud').unbind('click');
8
PurplePier

Ты можешь использовать

$("#btnAddProfile").text('Save');

хотя

$("#btnAddProfile").html('Save');

будет работать, но это вводит в заблуждение (создается впечатление, что вы могли бы написать что-то вроде 

$("#btnAddProfile").html('Save <b>now</b>');

но, конечно, вы не можете

8
gotofritz
document.getElementById('btnAddProfile').value='Save';
6
curtisk
$("#btnAddProfile").click(function(){
    $("#btnAddProfile").attr('value', 'Save');
 });
5
sauerburger

это работа для меня HTML:

<button type="button" class="btn btn-primary" id="btnSaveSchedule">abc</button>

jS

$("#btnSaveSchedule").text("new value");
4
Grey Wolf

Вы дали своей кнопке класс вместо идентификатора? попробуйте следующий код

$(".btnSave").attr('value', 'Save');
2
Nicholas Murray

$(document).ready(function(){
    $(":button").click(function(){
        $("p").toggle();

    if (this.value=="Add") this.value = "Save";
    else this.value = "Add";

  });
});
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
</head>
<body>

<input type='button' value='Add' id='btnAddProfile'>

<p>This is a paragraph with little content.</p>
<p>This is another small paragraph.</p>

</body>
</html>

2
Sudheer Kopparapu

Это должно сделать трюк:

$("#btnAddProfile").prop('value', 'Save');       
$("#btnAddProfile").button('refresh');
1
Olle Klang
$("#btnAddProfile").html('Save').button('refresh');
1
Drastick
    $( "#btnAddProfile" ).on( "click",function(event){
    $( event.target ).html( "Save" );
});
0
Rajesh M. Kanojia

Меняется название кнопки Этикет в C #.

<button type="submit" name="add" id="btnUpdate" class="btn btn-primary" runat="server" onserverclick="btnUpdate_Click">
Add

btnUpdate.**InnerText** = "Update";
0
Ismary Izquierdo
$("#btnviewdetails").click(function(){
    if($(this).val()!="hide details"){
        $("#detailedoutput").show();
        $(this).val('hide details');
    }else{
        $("#detailedoutput").hide();
        $(this).val('view more details');
    }

});
0
Feng

это совершенно правильно, это работает для меня;

    $('#btnAddProfile').bind('click',function(){
    $(this).attr('value','save');
})

вы уверены, что Jquery доступен и ваш код находится в правильном месте?

0
John Beynon