1, js base64
Get the uploaded file myfile, create a fileRead file object, and use the readAsDataURL method to encode the read file into a Data URL. After the file is loaded successfully, e.target.result is the base64 encoding corresponding to the file image. The image can be displayed by assigning the src of img directly.
<body> <input type="file" name="myfile" id="myfile" value="" onchange="sub()"/> </body> <script type="text/javascript"> function sub(){ var myfile = document.getElementById("myfile").files[0]; var fileRead = new FileReader(); fileRead.readAsDataURL(myfile); fileRead.onload = function(e){ console.log(e); var base64 = e.target.result; console.log(base64); var img = new Image(); img.src = base64; document.getElementsByTagName("body")[0].appendChild(img); } } <script>
The following is the result of e object printing in onload. You can see that e.target.result is the information of the file image.
data:image/s3,"s3://crabby-images/bf533/bf5337f57865dffee22ba8cf37f78203d5f295b0" alt=""
The code of base64 is printed below, which can be directly referenced in the src of img, or copied to the browser search box to search for pictures directly.
data:image/s3,"s3://crabby-images/7c344/7c344fd302ceaf46f4b241afa48fd6a051a4b774" alt=""
The operation result is as follows:
data:image/s3,"s3://crabby-images/73fe5/73fe5ef8f557f7f2e4ba03fa3b3d950afc07eedd" alt=""
2, canvas base64
Use canvas to draw a rectangle filled with red. After the pilot button, use the canvas.toDataURL method: return a data URI containing the image display. You can use the type parameter, which defaults to PNG format. Assign the base64 code to img's src to display the image.
<body> <canvas id="mycanvas" width="500" height="500"></canvas> <button onclick="sub()">click</button> </body> <script type="text/javascript"> var canvas = document.getElementById("mycanvas"); var context = canvas.getContext("2d"); context.beginPath(); context.fillStyle = "red"; context.fillRect(100,100,100,100); function sub(){ var base64 = canvas.toDataURL(); console.log(base64); var img = new Image(); img.src = base64; document.getElementsByTagName("body")[0].appendChild(img); } </script>
The results are as follows:
data:image/s3,"s3://crabby-images/c3b33/c3b3302138cbc6a021b884eb875d15852b562861" alt=""
The base64 method of two kinds of pictures is very practical, which may be encountered in the project development. Let's share it with you today.