<input>タグのv-modelの値をaxios経由でPOSTするコードを書きました。
<template>内の、v-model="title" と、v-model="comment"の値をsaveCanvas()関数内で取得し、POSTしたいのですが、下記コードの("title", this.title);の箇所で[Uncaught TypeError: Cannot read properties of undefined (reading 'title')] となり、v-modelの値が取得できません。
どうすれば、v-modelの情報を関数内で取得できるでしょうか?
javascript
1data.append("title", this.title); 2data.append("comment", this.comment);
コード全体は以下のように書いています。
javascript
1<template> 2 <div> 3 <!-- 画像エリア --> 4 <div id="image_area"> 5 <canvas ref="preview" id="preview"></canvas> 6 <input type="file" name="image" accept="image/*" ref="selectimage" @change="previewImage"/> 7 </div> 8 <p> 9 <input type="text" id="canvas_text" value="" /> 10 <button type="button" @click="drawText('preview', 'canvas_text')"> 11 文字を描く 12 </button> 13 </p> 14 15 <!-- タイトル入力 --> 16 <div> 17 <input v-model="title" type="text" name="title" placeholder="タイトル"> 18 </div> 19 <div> 20 <!-- コメント入力エリア --> 21 <textarea v-model="comment" name="comment" cols="30" rows="10" placeholder="コメント入力"></textarea> 22 </div> 23 <button @click="saveCanvas('preview')">アップロード</button> 24 25 <!-- input内容を表示 --> 26 <div> 27 <p>{{ title }}</p> 28 <p>{{ comment }}</p> 29 </div> 30 31 32 </div> 33</template> 34 35<script> 36export default { 37 38 data(){ 39 return { 40 title:"", 41 comment:"" 42 } 43 }, 44 45 methods: { 46 47 // Canvasのデータをblob化/title/commetをaxiosでPOST 48 saveCanvas: (canvas_id)=> { 49 const type = "image/png"; 50 const canvas = document.getElementById(canvas_id); 51 const dataurl = canvas.toDataURL("image/jpeg", 0.85); 52 const bin = atob(dataurl.split(",")[1]); 53 const buffer = new Uint8Array(bin.length); 54 for (let i = 0; i < bin.length; i++) { 55 buffer[i] = bin.charCodeAt(i); 56 } 57 58 const blob = new Blob([buffer.buffer], { type: type }); 59 60 //new FormData() を作成 61 const data = new FormData(); 62 data.append("canvas", blob, "png"); 63 data.append("title", this.title); 64 data.append("comment", this.comment); 65 66 67 axios 68 .post("/api/images", data) 69 .then((res) => { 70 console.log("success"); 71 }) 72 .catch((error) => { 73 new Error(error); 74 }); 75 console.log("hello"); 76 }, 77 }, 78 79}; 80 81</script>
しかし、下記コードの箇所で
「Uncaught TypeError: Cannot read properties of undefined (reading 'title')」と出て、v-modelの値が定数に代入されません。
javascript
1 //inputタグ v-model="title"の情報を定数titleに代入 2 const title = this.title; 3 //inputタグ v-model="title"の情報を定数titleに代入 4 const comment = this.comment;
v-modelの値はdata()でreturnされているのですが、定数に代入できません。
アドバイスをお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。