Le Dinh Nhat Khanh Le Dinh Nhat Khanh - 4 months ago 15
Ajax Question

Asp.net core bind data to button

I'm learning ASP.NET Core MVC.
I have this model:

public class Todo
public int Id { get; set; }
public string Name { get; set; }
public string Content { get; set; }
public bool isCompleted { get; set; } = false;
public DateTime DateCreated { get; set; } = DateTime.UtcNow;
public string UserName { get; set; }

And I want to bind the
to the button like: when I click that button, it's value will be changed. Currently I'm using Ajax:

CompleteTodo = function (id, isCompleted) {
if (isCompleted === true) {
var data = "{\n \"isCompleted\": false,\n}"
} else {
var data = "{\n \"isCompleted\": true,\n}"
var settings = {
"async": true,
"crossDomain": true,
"url": "http://localhost:3000/api/todos/"+id,
"method": "PUT",
"headers": {
"content-type": "application/json",
"cache-control": "no-cache",
"data": data

$.ajax(settings).done(function (response) {

The problem is, I can't change the button's class after the call, my button tag:

<button id="ButtonComplete" href="#" onclick='CompleteTodo(@item.Id,@item.isCompleted.ToString().ToLower())' class="waves-effect waves-light @(item.isCompleted?"blue":"green") btn">@if (!item.isCompleted)
{ <i class="material-icons">done</i>}
{ <i class="material-icons">clear</i> }</button>

So how can I do that? Thank you.


Since you use server side binding, button class does not change without refreshing page. Refresh the page when ajax completed:

$.ajax(settings).done(function (response) {

Or change class(add/remove) on the client side with javascript.

ps: Make sure after ajax call item.isCompleted changes as expected.