มาสก์ฟิลด์เป็นวิธีที่ผู้เรียก API ใช้เพื่อแสดงรายการฟิลด์ที่คำขอควร ส่งคืนหรืออัปเดต การใช้ FieldMask ช่วยให้ API ไม่ต้องทำงานที่ไม่จำเป็นและปรับปรุงประสิทธิภาพ ฟิลด์มาสก์ ใช้สำหรับทั้งเมธอดอ่านและอัปเดตใน Google สไลด์ API
หากต้องการเปรียบเทียบสิ่งที่ส่งคืนในเนื้อหาการตอบกลับเมื่อคุณไม่ได้ใช้ฟิลด์มาสก์กับเมื่อใช้ ให้ดูการทำงานกับทรัพยากรบางส่วน
อ่านด้วยฟิลด์มาสก์
งานนำเสนออาจมีขนาดใหญ่ และบ่อยครั้งที่คุณไม่จำเป็นต้องใช้ทุกส่วนของ
presentations
ทรัพยากรที่ส่งคืนโดยคำขออ่าน คุณจำกัดสิ่งที่แสดงผลในคำตอบของ Slides API ได้โดยใช้พารามิเตอร์ของ URL fields
เพื่อให้ได้ประสิทธิภาพสูงสุด ให้ระบุเฉพาะฟิลด์ที่คุณต้องการในการตอบกลับ
รูปแบบของพารามิเตอร์ฟิลด์จะเหมือนกับการเข้ารหัส JSON ของ FieldMask กล่าวโดยย่อคือฟิลด์ที่แตกต่างกันหลายรายการจะคั่นด้วยคอมมา และฟิลด์ย่อยจะคั่นด้วยจุด ระบุชื่อฟิลด์ได้ในรูปแบบ camelCase หรือ separated_by_underscores คุณสามารถระบุฟิลด์ย่อยหลายรายการจากประเภทเดียวกันภายในวงเล็บเพื่อความสะดวก
ตัวอย่างคำขอเมธอดต่อไปนี้
presentations.get
ใช้มาสก์ฟิลด์ของ
slides.pageElements(objectId,size,transform)
เพื่อดึงเฉพาะรหัสออบเจ็กต์
Size
และ
transform
ของออบเจ็กต์
pageElement
ในสไลด์ทั้งหมดในงานนำเสนอ
GET https://slides.googleapis.com/v1/presentations/presentationId?fields=slides.pageElements(objectId,size,transform)
การตอบกลับการเรียกใช้เมธอดนี้คือออบเจ็กต์
presentations
ที่มีคอมโพเนนต์ที่ขอในมาสก์ฟิลด์
{ "slides": [ { "pageElements": [ { "objectId": "OBJECT_ID
", "size": { "width": { "magnitude": 3000000, "unit": "EMU" }, "height": { "magnitude": 3000000, "unit": "EMU" } }, "transform": { "scaleX": 1, "scaleY": 1 "translateX": 311708, "translateY": 744575, "unit": "EMU" } }, { "objectId": "OBJECT_ID
", "size": { "width": { "magnitude": 3000000, "unit": "EMU" }, "height": { "magnitude": 3000000, "unit": "EMU" } }, "transform": { "scaleX": 1, "scaleY": 1 "translateX": 311700, "translateY": 2834125, "unit": "EMU" } } ] } ] }
อัปเดตด้วยมาสก์ฟิลด์
บางครั้งคุณอาจต้องอัปเดตเฉพาะบางฟิลด์ในออบเจ็กต์โดยปล่อยให้ฟิลด์อื่นๆ
ไม่เปลี่ยนแปลง คำขออัปเดตภายในเมธอด
presentations.batchUpdate
จะใช้มาสก์ฟิลด์เพื่อบอก API ว่ามีการเปลี่ยนแปลงฟิลด์ใด
คำขออัปเดตจะละเว้นฟิลด์ที่ไม่ได้ระบุในฟิลด์มาสก์
และคงค่าปัจจุบันไว้
นอกจากนี้ คุณยังยกเลิกการตั้งค่าฟิลด์ได้โดยไม่ระบุฟิลด์ในข้อความที่อัปเดต แต่ เพิ่มฟิลด์ลงในมาสก์ ซึ่งจะล้างค่าใดก็ตามที่ฟิลด์มีอยู่ก่อนหน้านี้
ไวยากรณ์สำหรับมาสก์ฟิลด์การอัปเดตจะเหมือนกับมาสก์ฟิลด์การอ่าน
ตัวอย่างต่อไปนี้ใช้เมธอด
UpdateShapePropertiesRequest
เพื่อเปลี่ยนการเติมสีของรูปร่างเป็นสีธีม DARK1
และยกเลิกการตั้งค่า
เส้นขอบของรูปร่าง
POST https://slides.googleapis.com/v1/presentations/presentationId:batchUpdate
{
"requests": [
{
"updateShapeProperties": {
"objectId": OBJECT_ID
,
"shapeProperties": {
"shapeBackgroundFill": {
"solidFill": {
"color": {
"themeColor": "DARK1"
}
}
}
},
"fields": "shapeBackgroundFill.solidFill.color,outline"
}
}
]
}