วิธีการเปลี่ยนค่าของวัตถุที่อยู่ในอาร์เรย์โดยใช้ JavaScript หรือ jQuery


206

รหัสด้านล่างมาจากการเติมข้อความอัตโนมัติ jQuery UI:

var projects = [
    {
        value: "jquery",
        label: "jQuery",
        desc: "the write less, do more, JavaScript library",
        icon: "jquery_32x32.png"
    },
    {
        value: "jquery-ui",
        label: "jQuery UI",
        desc: "the official user interface library for jQuery",
        icon: "jqueryui_32x32.png"
    },
    {
        value: "sizzlejs",
        label: "Sizzle JS",
        desc: "a pure-JavaScript CSS selector engine",
        icon: "sizzlejs_32x32.png"
    }
];

ตัวอย่างเช่นผมต้องการเปลี่ยนค่ารายละเอียดของ jQuery ฉันจะทำสิ่งนั้นได้อย่างไร

นอกจากนี้มีวิธีที่เร็วกว่าในการรับข้อมูลหรือไม่ ฉันหมายถึงให้วัตถุชื่อเพื่อดึงข้อมูลเช่นเดียวกับวัตถุในอาร์เรย์? ดังนั้นมันจะเป็นอย่างไรjquery-ui.jquery-ui.desc = ....


projects["jquery-ui"].descคุณจะต้องเปลี่ยนอาร์เรย์เป็นวัตถุจาวาสคริปต์ในการใช้ไวยากรณ์ นั่นจะคุ้มค่ากับความพยายามเพียงเพื่อให้ได้ไวยากรณ์ที่ดีขึ้นหรือไม่
Frédéric Hamidi

ฉันได้อัปเดตโซลูชันด้วยคำถามล่าสุดของคุณแล้ว และคุณสามารถใช้สัญลักษณ์ "projects.jquery-ui.desc"
แอสตัน

คำตอบ:


135

คุณต้องค้นหาในอาเรย์เช่น:

function changeDesc( value, desc ) {
   for (var i in projects) {
     if (projects[i].value == value) {
        projects[i].desc = desc;
        break; //Stop this loop, we found it!
     }
   }
}

และใช้มันเหมือน

var projects = [ ... ];
changeDesc ( 'jquery-ui', 'new description' );

UPDATE:

เพื่อให้เร็วขึ้น:

var projects = {
   jqueryUi : {
      value:  'lol1',
      desc:   'lol2'
   }
};

projects.jqueryUi.desc = 'new string';

(ตามความคิดเห็นของFrédéricคุณไม่ควรใช้เครื่องหมายยัติภังค์ในคีย์วัตถุหรือคุณควรใช้เครื่องหมาย "jquery-ui" และโครงการ ["jquery-ui"])


มีวิธีที่เร็วกว่ามากในการรับข้อมูลหรือไม่ ฉันหมายถึงให้วัตถุชื่อเพื่อดึงข้อมูลของมันเพียงแค่วัตถุในอาร์เรย์ดังนั้นฉันสามารถใช้ในวิธีที่: jquery-ui.jquery-ui.desc = ....
qinHaiXiang

2
การอัปเดตของคุณจะไม่ทำงานเนื่องจากยัติภังค์-ในชื่อวัตถุ คุณจะต้องเขียน"jquery-ui": {}และprojects["jquery-ui"].descตามลำดับ
Frédéric Hamidi

ขอบคุณฉันไม่รู้
Aston

ดูคำตอบของ abe kur นั่นคือสิ่งที่ถูกต้องสิ่งนี้และ
เพศหญิง

237

มันค่อนข้างง่าย

  • ค้นหาดัชนีของวัตถุโดยใช้findIndexวิธีการ
  • เก็บดัชนีในตัวแปร
  • ทำการอัปเดตอย่างง่ายดังนี้: yourArray[indexThatyouFind]

//Initailize array of objects.
let myArray = [
  {id: 0, name: "Jhon"},
  {id: 1, name: "Sara"},
  {id: 2, name: "Domnic"},
  {id: 3, name: "Bravo"}
],
    
//Find index of specific object using findIndex method.    
objIndex = myArray.findIndex((obj => obj.id == 1));

//Log object to Console.
console.log("Before update: ", myArray[objIndex])

//Update object's name property.
myArray[objIndex].name = "Laila"

//Log object to console again.
console.log("After update: ", myArray[objIndex])


2
เหตุผลใดที่เป็นสองเท่า()ในfindIndexวิธีการ?
Terkhos

3
มันจะกลายพันธุ์ myArray
Bimal Grg

1
ใช่ แต่ถ้าคุณไม่ต้องการที่จะกลายพันธุ์ [...myArray.slice(0, objIndex), Object.assign({}, myArray[objIndex], myArray.slice(objIndex + 1))]
Umair Ahmed

1
@UmairAhmed ไม่ควรใช้รหัสด้านบน [...myArray.slice(0, objIndex), Object.assign({}, myArray[objIndex], ...myArray.slice(objIndex + 1))]? ฉันคิดว่าคุณพลาดวงรีที่สอง
เครก

1
รักวิธีทำความสะอาดนี้!
tdelam

58

วิธีES6โดยไม่ปิดบังข้อมูลต้นฉบับ

var projects = [
{
    value: "jquery",
    label: "jQuery",
    desc: "the write less, do more, JavaScript library",
    icon: "jquery_32x32.png"
},
{
    value: "jquery-ui",
    label: "jQuery UI",
    desc: "the official user interface library for jQuery",
    icon: "jqueryui_32x32.png"
}];

//find the index of object from array that you want to update
const objIndex = projects.findIndex(obj => obj.value === 'jquery-ui');

// make new object of updated object.   
const updatedObj = { ...projects[objIndex], desc: 'updated desc value'};

// make final new array of objects by combining updated object.
const updatedProjects = [
  ...projects.slice(0, objIndex),
  updatedObj,
  ...projects.slice(objIndex + 1),
];

console.log("original data=", projects);
console.log("updated data=", updatedProjects);

57

ทางออกที่ดีที่สุดต้องขอบคุณ ES6

ส่งคืนอาร์เรย์ใหม่พร้อมคำอธิบายที่ถูกแทนที่สำหรับวัตถุที่มีค่าเท่ากับ "jquery-ui"

const newProjects = projects.map(p =>
  p.value === 'jquery-ui'
    ? { ...p, desc: 'new description' }
    : p
);

1
แน่นอนทางออกที่แท้จริงที่ดีที่สุด! ขอบคุณ
Frederiko Cesar

1
@FrederikoCesar ไม่ได้ในทุกกรณีการวนซ้ำของแต่ละวัตถุมีค่ามากกว่าการแบ่งอาร์เรย์และฉีดวัตถุใหม่โดยใช้ตัวดำเนินการแพร่กระจาย
Maged Mohamed

ถ้าคุณต้องการเปลี่ยนค่าในทันที? โดยไม่ต้องสร้าง var อื่นหรือไม่ วิธีที่ดีที่สุดคือวิธีดัชนี: const targetIndex = summerFruits.findIndex (f => f.id === 3);
Thanasis

37

คุณสามารถใช้$ .each ()เพื่อวนซ้ำแถวลำดับและค้นหาวัตถุที่คุณสนใจ:

$.each(projects, function() {
    if (this.value == "jquery-ui") {
        this.desc = "Your new description";
    }
});

36

การใช้แผนที่เป็นทางออกที่ดีที่สุดโดยไม่ต้องใช้ไลบรารีเพิ่มเติม (ใช้ ES6)

const state = [
{
    userId: 1,
    id: 100,
    title: "delectus aut autem",
    completed: false
},
{
    userId: 1,
    id: 101,
    title: "quis ut nam facilis et officia qui",
    completed: false
},
{
    userId: 1,
    id: 102,
    title: "fugiat veniam minus",
    completed: false
},
{
    userId: 1,
    id: 103,
    title: "et porro tempora",
    completed: true
}]

const newState = state.map(obj =>
    obj.id === "101" ? { ...obj, completed: true } : obj
);

19

สามารถทำได้โดยง่ายด้วยการขีดเส้นใต้ / lodash ไลบรารี่:

  _.chain(projects)
   .find({value:"jquery-ui"})
   .merge({desc: "new desc"});

เอกสาร:
https://lodash.com/docs#find
https://lodash.com/docs#merge


จะเกิดอะไรขึ้นถ้าไม่พบ 'jquery-ui' ในฟังก์ชัน find?
มิกะ

ไม่มีคุณสมบัติ 'ค้นหา' ในประเภท 'LoDashExplicitArrayWrapper'
AndrewBenjamin

ผลลัพธ์ของลำดับดังกล่าวจะต้องถูกเปิดด้วยค่า _ # lodash.com/docs/4.17.4#chain .value()
p0k8_

17

คุณสามารถใช้. ค้นหาในตัวอย่างของคุณ

   var projects = [
            {
                value: "jquery",
                label: "jQuery",
                desc: "the write less, do more, JavaScript library",
                icon: "jquery_32x32.png"
            },
            {
                value: "jquery-ui",
                label: "jQuery UI",
                desc: "the official user interface library for jQuery",
                icon: "jqueryui_32x32.png"
            },
            {
                value: "sizzlejs",
                label: "Sizzle JS",
                desc: "a pure-JavaScript CSS selector engine",
                icon: "sizzlejs_32x32.png"
            }
        ];

let project = projects.find((p) => {
    return p.value === 'jquery-ui';
});

project.desc = 'your value'

! ที่น่าตื่นตาตื่นใจ +1
Mike Musni

12

คุณจำเป็นต้องรู้ดัชนีของวัตถุที่คุณกำลังเปลี่ยน แล้วมันค่อนข้างง่าย

projects[1].desc= "new string";

8

ฉันคิดว่าวิธีนี้ดีกว่า

const index = projects.findIndex(project => project.value==='jquery-ui');
projects[index].desc = "updated desc";

ในของfindIndexคุณคุณกำลังกำหนดค่าแทนการเปรียบเทียบ
avalanche1

7

ให้ข้อมูลต่อไปนี้เราต้องการที่จะเปลี่ยนเบอร์รี่ในsummerFruitsรายการที่มีแตงโม

const summerFruits = [
{id:1,name:'apple'}, 
{id:2, name:'orange'}, 
{id:3, name: 'berries'}];

const fruit = {id:3, name: 'watermelon'};

คุณสามารถทำได้สองวิธี

วิธีแรก:

//create a copy of summer fruits.
const summerFruitsCopy = [...summerFruits];

//find index of item to be replaced
const targetIndex = summerFruits.findIndex(f=>f.id===3); 

//replace the object with a new one.
summerFruitsCopy[targetIndex] = fruit;

แนวทางที่สอง: การใช้mapและspread:

const summerFruitsCopy = summerFruits.map(fruitItem => 
fruitItem .id === fruit.id ? 
    {...summerFruits, ...fruit} : fruitItem );

summerFruitsCopy รายการตอนนี้จะส่งคืนอาร์เรย์ด้วยวัตถุที่อัปเดต


วิธีแรกดีที่สุด ไม่จำเป็นต้องย้ายไปยังอีก var แล้วกลับมา เกี่ยวกับวิธีการบิน ฉันขึ้นคะแนนโซลูชันของคุณแล้ว
Thanasis

4

// using higher-order functions to avoiding mutation
var projects = [
            {
                value: "jquery",
                label: "jQuery",
                desc: "the write less, do more, JavaScript library",
                icon: "jquery_32x32.png"
            },
            {
                value: "jquery-ui",
                label: "jQuery UI",
                desc: "the official user interface library for jQuery",
                icon: "jqueryui_32x32.png"
            },
            {
                value: "sizzlejs",
                label: "Sizzle JS",
                desc: "a pure-JavaScript CSS selector engine",
                icon: "sizzlejs_32x32.png"
            }
        ];

// using higher-order functions to avoiding mutation
index = projects.findIndex(x => x.value === 'jquery-ui');
[... projects.slice(0,index), {'x': 'xxxx'}, ...projects.slice(index + 1, projects.length)];


นี้...ก่อนที่โครงการที่มีความจำเป็น?
lazzy_ms

@lazzy_ms the ...เป็นที่รู้จักกันว่าเป็นตัวดำเนินการสเปรด google it :)
rmcsharry

4

findนี่คือคำตอบที่เกี่ยวข้องอีก สิ่งนี้ขึ้นอยู่กับข้อเท็จจริงที่find:

  • วนซ้ำทุกวัตถุในอาร์เรย์จนกระทั่งพบการจับคู่
  • แต่ละวัตถุมีให้กับคุณและสามารถปรับเปลี่ยนได้

นี่คือข้อมูลโค้ด Javascript ที่สำคัญ:

projects.find( function (p) {
    if (p.value !== 'jquery-ui') return false;
    p.desc = 'your value';
    return true;
} );

นี่คือ Javascript รุ่นเดียวกันที่เป็นทางเลือก:

projects.find( function (p) {
    if (p.value === 'jquery-ui') {
        p.desc = 'your value';
        return true;
    }
    return false;
} );

นี่เป็นเวอร์ชั่นที่สั้นกว่า (และค่อนข้างชั่วร้ายกว่า):

projects.find( p => p.value === 'jquery-ui' && ( p.desc = 'your value', true ) );

นี่คือเวอร์ชันการทำงานที่สมบูรณ์:

  var projects = [
            {
                value: "jquery",
                label: "jQuery",
                desc: "the write less, do more, JavaScript library",
                icon: "jquery_32x32.png"
            },
            {
                value: "jquery-ui",
                label: "jQuery UI",
                desc: "the official user interface library for jQuery",
                icon: "jqueryui_32x32.png"
            },
            {
                value: "sizzlejs",
                label: "Sizzle JS",
                desc: "a pure-JavaScript CSS selector engine",
                icon: "sizzlejs_32x32.png"
            }
        ];

projects.find( p => p.value === 'jquery-ui' && ( p.desc = 'your value', true ) );

console.log( JSON.stringify( projects, undefined, 2 ) );


3

คุณสามารถใช้ฟังก์ชั่นแผนที่ -

const answers = this.state.answers.map(answer => {
  if(answer.id === id) return { id: id, value: e.target.value }
  return answer
})

this.setState({ answers: answers })


0

นอกจากนี้เรายังสามารถใช้ฟังก์ชั่นแผนที่ของ Array เพื่อแก้ไขวัตถุของอาเรย์โดยใช้ Javascript

function changeDesc(value, desc){
   projects.map((project) => project.value == value ? project.desc = desc : null)
}

changeDesc('jquery', 'new description')

สิ่งนี้จะส่งกลับ [null, วัตถุที่มีค่าที่อัปเดต, null]
Fernando Caride

0

ค้นหาดัชนีก่อน:

function getIndex(array, key, value) {
        var found = false;
        var i = 0;
        while (i<array.length && !found) {
          if (array[i][key]==value) {
            found = true;
            return i;
          }
          i++;
        }
      }

แล้ว:

console.log(getIndex($scope.rides, "_id", id));

จากนั้นทำสิ่งที่คุณต้องการด้วยดัชนีนี้เช่น:

$ scope [returnindex] .someKey = "someValue";

หมายเหตุ: โปรดอย่าใช้สำหรับเพราะจะตรวจสอบเอกสารอาร์เรย์ทั้งหมดใช้ในขณะที่มีตัวหยุดดังนั้นมันจะหยุดเมื่อมันถูกค้นพบแล้วจึงทำให้โค้ดเร็วขึ้น


0

ที่นี่ฉันใช้ js เชิงมุม ในจาวาสคริปต์คุณสามารถใช้เพื่อหาวง

    if($scope.bechval>0 &&$scope.bechval!=undefined)
    {

                angular.forEach($scope.model.benhmarkghamlest, function (val, key) {
                $scope.model.benhmarkghamlest[key].bechval = $scope.bechval;

            });
    }
    else {
        alert("Please sepecify Bechmark value");
    }

0

ลองใช้forEach(item,index)ผู้ช่วย

var projects = [
    {
        value: "jquery",
        label: "jQuery",
        desc: "the write less, do more, JavaScript library",
        icon: "jquery_32x32.png"
    },
    {
        value: "jquery-ui",
        label: "jQuery UI",
        desc: "the official user interface library for jQuery",
        icon: "jqueryui_32x32.png"
    },
    {
        value: "sizzlejs",
        label: "Sizzle JS",
        desc: "a pure-JavaScript CSS selector engine",
        icon: "sizzlejs_32x32.png"
    }
];

let search_to_change = 'jquery'

projects.forEach((item,index)=>{
   if(item.value == search_to_change )
      projects[index].desc = 'your description ' 
})

-1

เพื่ออัปเดตหลายรายการด้วยการใช้ไม้ขีดไฟ:

_.chain(projects).map(item => {
      item.desc = item.value === "jquery-ui" ? "new desc" : item.desc;
      return item;
    })

-1

นี่คือการตอบสนองต่อปัญหาของฉัน เวอร์ชั่นขีดล่างของฉันคือ 1.7 ดังนั้นฉันจึงไม่สามารถใช้งาน.findIndexได้

ดังนั้นฉันจึงได้ดัชนีของรายการและแทนที่ด้วยตนเอง นี่คือรหัสสำหรับเดียวกัน

 var students = [ 
{id:1,fName:"Ajay", lName:"Singh", age:20, sex:"M" },
{id:2,fName:"Raj", lName:"Sharma", age:21, sex:"M" },
{id:3,fName:"Amar", lName:"Verma", age:22, sex:"M" },
{id:4,fName:"Shiv", lName:"Singh", age:22, sex:"M" }
               ]

วิธีการด้านล่างจะแทนที่นักเรียนด้วยid:4คุณลักษณะเพิ่มเติมในวัตถุ

function updateStudent(id) {
 var indexOfRequiredStudent = -1;
    _.each(students,function(student,index) {                    
      if(student.id === id) {                        
           indexOfRequiredStudent = index; return;      
      }});
 students[indexOfRequiredStudent] = _.extend(students[indexOfRequiredStudent],{class:"First Year",branch:"CSE"});           

}

ด้วยขีด 1.8 _.findIndexOfมันจะได้ง่ายในขณะที่เรามีวิธีการ


-1

ให้คุณต้องการอัปเดตค่าของ array[2] = "data"

    for(i=0;i<array.length;i++){
      if(i == 2){
         array[i] = "data";
        }
    }

นี่เป็นคำตอบหรือคำถาม?
tabdiukov

2
คุณอัปเดตไอเท็มที่ 2 ในอาร์เรย์นั้นสำเร็จในวิธีที่ซับซ้อนที่สุดเท่าที่จะเป็นไปได้
BlueWater86

-1
let thismoth = moment(new Date()).format('MMMM');
months.sort(function (x, y) { return x == thismoth ? -1 : y == thismoth ? 1 : 0; });

1
โปรดระบุคำอธิบายให้กับคำตอบของคุณ
Lajos Arpad
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.