整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          JavaScript 上傳圖片的簡單例子

          JavaScript中,您可以使用HTML5的<input type="file">元素來實現圖片上傳功能。

          以下是一個簡單的示例代碼,演示如何在JavaScript中上傳圖片:

          HTML部分:

          <input type="file" id="uploadInput">
          <button onclick="uploadImage()">上傳圖片</button>
          

          JavaScript部分:

          function uploadImage() {
            var fileInput = document.getElementById('uploadInput');
            var file = fileInput.files[0];
          
            if (file) {
              var formData = new FormData();
              formData.append('image', file);
          
              // 發送圖片數據到服務器
              // 這里可以使用XMLHttpRequest或fetch等方法發送請求
              // 請根據您的需求選擇適當的方法
              // 示例中使用XMLHttpRequest發送POST請求
              var xhr = new XMLHttpRequest();
              xhr.open('POST', '/upload', true);
              xhr.onload = function() {
                if (xhr.status === 200) {
                  // 上傳成功
                  console.log('圖片上傳成功');
                } else {
                  // 上傳失敗
                  console.log('圖片上傳失敗');
                }
              };
              xhr.send(formData);
            }
          }
          

          API部分:

          [HttpPost]
          [RequestSizeLimit(5242880)]
           public async Task<APIResult> upload(IFormCollection collection)
           {
          
                      APIResult rtn = new APIResult();
          
                      if (collection == null)
                      {
                          rtn.code = -100;
                          rtn.msg = "圖片列表為空";
                          return rtn;
                      }
                      else
                      {
                          try
                          {
                              string file_path = "";
                              // 預處理 用戶參數:用戶指定子路徑                   
                              string userPath = DateTime.Now.ToString("yyyy-MM-dd");
                              if (collection.ContainsKey("path"))
                              {
                                  collection.TryGetValue("path", out Microsoft.Extensions.Primitives.StringValues val);
                                  if (!val.Equals("undefined"))
                                  {
                                      userPath = val.ToString();
                                  }
                              }
          
                              // 預處理 文件路徑
                              // 注意:這里可能會根據不同的環境來 修改 路徑前面是否需要添加 /
                              // 當發現上傳不成功,目錄無法創建時,可以嘗試修改這里
                              file_path = $"upload/imgs/{userPath}/";
                              var uploadPath = Path.Combine(_webHostEnvironment.WebRootPath, file_path);
                              if (!Directory.Exists(uploadPath))
                              {
                                  Directory.CreateDirectory(uploadPath);
                              }
          
                              // 處理文件
                              FormFileCollection filelist = (FormFileCollection)collection.Files;
                              foreach (IFormFile file in filelist)
                              {
                                  // 保存文件到磁盤
                                  string name = file.FileName;
                                  string FilePath = Path.Combine(uploadPath, name);
                                  string type = Path.GetExtension(name);
                                  using (var stream = System.IO.File.Create(FilePath))
                                  {
                                      await file.CopyToAsync(stream);
                                  };
          
                                  // 保存文件信息到表
                                  Sys_File f = new Sys_File();
                                  f.code = "image";
                                  f.name = name;
                                  f.file_type = type.Trim('.');
                                  f.file_group = userPath;
                                  f.file_path = $"/{file_path}{name}";
                                  f.is_active = true;
                                  f.memo = "";
                                  f.createTime = DateTime.Now;
                                  using (var dbctx = DBHelper.db)
                                  {
                                      await dbctx.AddAsync(f);
                                      await dbctx.SaveChangesAsync();
                                  };
                                  // 返回消息,包含文件路徑
                                  rtn.datas = $"/{file_path}{name}";
                                  rtn.code = 100;
                                  rtn.msg = "文件已保存!";
                              }
                          }
                          catch (Exception ex)
                          {
                              rtn.code = -200;
                              rtn.msg = "圖片保存失敗!";
                              Log4NetUnit.Instance.Log.Error("圖片保存失敗:" + ex.Message);
                          }
                          return rtn;
                      }
                  }


          在這個示例中,我們首先在HTML中創建了一個<input type="file">元素,用于選擇要上傳的圖片。

          然后,我們在JavaScript中編寫了一個uploadImage函數,該函數在點擊"上傳圖片"按鈕時觸發。

          uploadImage函數中,我們首先獲取到<input>元素,并從中獲取到用戶選擇的圖片文件。

          然后,我們創建一個FormData對象,并將圖片文件添加到其中。

          接下來,我們可以使用XMLHttpRequest或fetch等方法將圖片數據發送到服務器。

          在示例中,我們使用XMLHttpRequest發送了一個POST請求,將圖片數據作為FormData發送到/upload端點。

          您需要根據您的實際情況修改URL和請求方法。

          當請求完成時,我們可以根據響應的狀態碼來判斷上傳是否成功。

          在示例中,如果狀態碼為200,則表示上傳成功,否則表示上傳失敗。

          請注意,由于安全性限制,JavaScript無法直接訪問用戶的文件系統。

          因此,用戶必須手動選擇要上傳的文件。

          網絡上,有序列表可以使您的 HTML 頁面更有組織、簡潔且易于閱讀。在本文中,我將向您展示如何在 HTML 中創建高質量、有趣的有序列表。您將學習如何在平凡的列表中帶來鮮為人知的"Wow"效果。讓我們開始吧!


          一、HTML 中的 ordered list 基礎

          HTML 中的有序列表(ordered list)使用 <ol> 元素創建,并且對于每個列表項使用 <li> 元素。下面是一段有序列表的基本示例:

          html
          <ol>
          <li>項目 1</li>
          <li>項目 2</li>
          </ol>
          

          在上面的示例中,您可以看到列表由 <ol> 元素包圍,每個列表項使用 <li> 元素表示。

          二、美化有序列表

          要讓您的有序列表更具吸引力,您可以通過使用 CSS 進行累積 з?熄culation。以下是一些建議:

          1. 自定義列表部分的風格: affair CAN I USE CSS 屬性供您選擇,例如顏色、背景圖片、邊框、邊距和填充。此外,可以使用盒子陰影為列表添加淺顯的三維效果。
          2. 更新列表標記: 更先Progressive Enhancement,在文本內容之前使用數字列表標記,可以讓列表更立體。您可以使用 CSS Counter 功能自動結合標記和內容。
          css

          像處理庫 (IML) 用于對圖像執行各種處理功能:你可以增加圖像的亮度、添加飽和度或濾鏡、裁剪和調整大小,以及更多有價值的功能,這些功能將幫助你完成幾乎所有事情并將你的網絡瀏覽器變成 Adob?e Lightroom!

          我們為每項重要的圖像處理任務都提供了庫,從簡單的低級操作(例如濾鏡、亮度和飽和度)到用于裁剪或圖像合成的單一用途庫。最后,我們進入了圖像測試領域,因為沒有可靠的方法來測試結果,任何圖像處理應用程序都是不完整的。

          NSDT工具推薦: Three.js AI紋理開發包 - YOLO合成數據生成器 - GLTF/GLB在線編輯 - 3D模型格式在線轉換 - 可編程3D場景編輯器 - REVIT導出3D模型插件 - 3D模型語義搜索引擎 - Three.js虛擬軸心開發包 - 3D模型在線減面 - STL模型在線切割

          1、Sharp

          Sharp 是一個高性能 Node.js 圖像處理庫,用于調整不同圖像格式(如 JPEG、PNG、WebP、AVIF、SVG 和 TIFF)的大小。此高速 Node.js 模塊的典型用例是將標準格式的大圖像轉換為較小的、適合網絡的圖像。

          只有當你想調整大型文件或多種文件的大小時,Sharp 才有用。另一方面,如果你只想調整單個小圖像的大小,那么可能不應該使用它。相反,普通的 HTML 和原生 JavaScript 會更有用。Sharp 充分利用了多個 CPU 核心和 L1/L2/L3 緩存,讓你可以更快地調整和壓縮圖像。

          用例

          我用它來調整整個 NFT 集合的大小,大小超過 80Gb,壓縮后大約為 10Gb。所以,如果你想使用它來調整幾張大圖像的大小,那么它是你的最佳選擇 - 你將以最快、最有效的方式完成它。

          示例

          你可以使用以下命令安裝此庫:

          npm install sharp

          使用 sharp 調整圖像大小的方法如下:

          const sharp = require('sharp');
          const fs = require('fs');
          
          sharp('yellow.png')
              .rotate(180)
              .resize(200)
              .toBuffer()
              .then( data => {
                  fs.writeFileSync('yellow.png', data);
              })
              .catch( err => {
                  console.log(err);
              });

          2、Cropper.js

          Cropper.js 是另一個流行的圖像處理 JavaScript 庫。你可以使用它以各種可能的方式裁剪圖像、更改縱橫比、旋轉、縮放和處理畫布數據。Cropper.js 是裁剪的正確選擇,無需任何額外功能。

          用例

          你可以使用其靈活的 API 在你的 Web 應用中創建自定義圖像裁剪 UI,讓你的用戶可以將照片調整為正確的大小和縱橫比。它將更加高效,因為它幾乎不需要任何東西,沒有任何無用的功能,并且非常適合裁剪!

          示例

          可以使用以下命令安裝此庫:

          npm install cropperjs
          import Cropper from 'cropperjs';
          
          const image = document.getElementById('image');
          const cropper = new Cropper(image, {
            aspectRatio: 16 / 9,
            crop(event) {
              console.log(event.detail.x);
              console.log(event.detail.y);
              console.log(event.detail.width);
              console.log(event.detail.height);
              console.log(event.detail.rotate);
              console.log(event.detail.scaleX);
              console.log(event.detail.scaleY);
            },
          });

          查看 Cropper.js 演示,單擊要應用于圖像的任何屬性并立即查看結果。

          有關如何將圖像裁剪添加到 React 應用的詳細指南,請查看使用 react-image-crop 的指南。

          3、合并圖像

          使用畫布可能有點乏味,尤其是當你需要畫布上下文來執行相對簡單的事情(例如合并幾張圖像)時。Merge Images將所有重復任務抽象為簡單的函數調用。它是 Canvas API 的包裝器,抽象了其低級函數,這使得這項特定任務變得容易得多。你還可以創建參數,例如定位、不透明度等。你可以在 GitHub 上的文檔中找到它們。

          用例

          這是一個有價值的庫,可以幫助完成多項任務。例如,你可以生成一個 NFT 集合,你可以在其中合并所有組件以獲得一套完整的變體。或者你會發現這個庫對個人使用很有幫助,例如,組合幾張不同的圖像來生成拼貼畫。

          示例

          安裝庫本身:

          npm install --save merge-images

          然后可以使用此代碼生成一個簡單的圖像:

          //write this inside of your javascript file
          
          import mergeImages from 'merge-images';
          
          mergeImages(['/body.png', '/eyes.png', '/mouth.png'])
            .then(b64 => document.querySelector('img').src = b64);
          
          //And that would update the img element to show this image:

          在這里,我用它來合并幾個組件來創建最終的變體(這里我使用了背景、角色、喇叭、情感和配件):

          4、LooksSame

          LooksSame 是一個用于比較圖像的庫。如果你上傳的兩張圖片是重復的,該庫會通知你。你所要做的就是提供想要比較的圖片的鏈接。LooksSame 嚴格來說不是一個圖像處理庫,但對測試很有幫助。

          用例

          你可以使用這個庫并編寫代碼來實現自動化和循環周期,以搜索目錄并比較每對圖像是否存在重復。此外,你還可以刪除這些重復項并自動執行此過程。如果經常使用包含大量圖像的 ML 算法,那么這是一個很棒的庫。

          示例

          要開始比較圖像,只需使用以下命令安裝它:

          npm i looks-same

          在這里,你可以看到如何使用 Jest 測試這個庫:

          var looksSame = require('looks-same');
          
          //Parameters can be paths to files or buffer with compressed png image
          
          test('image1 and image2 are the same', async () => {
          	expect(looksSame('image1.png', 'image2.png')).toBe(true);
          });
          
          //Result will be "image1 and image2 are the same" if they are the same
          

          5、Jimp

          Jimp 代表 JavaScript 圖像處理程序,它允許你以幾乎所有可能的方式編輯圖像。有了它,你可以反轉圖像、添加一些文本、調整大小、使用像素化、克隆圖像、模糊圖像、反轉顏色,以及其他一些很酷的功能,這些功能將提高應用程序的圖像處理能力。

          用例

          使用 Jimp,你可以構建 Web 應用程序,在其中幾乎可以以任何可能的方式編輯和處理圖像。裁剪、調整大小、旋轉和過濾功能讓你可以創建自己的照片編輯器并在其上添加界面。

          示例

          以下是嘗試這個優秀庫的 JavaScript 代碼。有一個異步函數,你可以在其中看到許多類型的屬性,你可以輕松更改這些屬性。例如添加文本、調整圖像大小、模糊圖像等。要使用其中至少一個,你只需要取消注釋需要的部分,然后程序就可以運行了!

          // Import dependencies
          const Jimp = require("jimp");
          
          (async function () {
          
              // Read the image
              const image = await Jimp.read("images/shapes.png"); // <http://www.example.com/path/to/lenna.jpg>
          
              // // Add text
              //  const font = await Jimp.loadFont(Jimp.FONT_SANS_16_WHITE); // bitmap fonts
              //  image.print(font, 0, 0, 'Hello world!'); // <https://github.com/libgdx/libgdx/wiki/Hiero>
          
              //  // Resize the image 
              //  // Resize the image to 250 x 250
              //  image.resize(250, 250);
          
              //  // Resize the height to 250 and scale the width accordingly
              //  image.resize(Jimp.AUTO, 250);
          
              //  // Resize the width to 250 and scale the height accordingly
              //  image.resize(250, Jimp.AUTO);
          
              //  // Add a sepia wash to the image
              //  image.sepia();
          
              //  // Pixelation 
              //  image.pixelate(5);
              //  image.pixelate(5, 50, 50, 190, 200); pixe,x, y, w, h 
          
              //  // Clone
              //  const image2 = image.clone();
          
              //  // Blur the image
              //  image.gaussian(1);
              //  image.blur(1);
          
              //  // Inverts the image
              //  image.invert(); 
          
              //  // Set the brightness
              //  image.brightness( 0.5 ); // -1 to +1
          
              //  // Resize the image
              //  image.resize(256, 256);
          
              //  // Set the quality
              //  image.quality(100);
          
              //  // Convert to grayscale
              //  image.greyscale();
          
              // Save the image
              image.write("images/edited-shapes.png"); // writeAsync
          
          })();
          

          PS:不要忘記取消注釋你想要使用的效果,然后保存文件。:)

          正如你在此處看到的,我模糊了所有內容并反轉了之前向你展示的圖像的顏色,得到了以下結果:


          原文鏈接:Top5圖像處理JS庫 - BimAnt


          主站蜘蛛池模板: 中文字幕一区二区三区精华液| 国产区精品一区二区不卡中文| 亚洲av乱码一区二区三区| 国产精品一区二区毛卡片| 亚洲国产精品综合一区在线 | 亚洲A∨精品一区二区三区下载| 精品一区二区三区色花堂| 日本不卡一区二区三区视频| 国产婷婷色一区二区三区| 国精产品一区二区三区糖心 | 国产99精品一区二区三区免费| 内射少妇一区27P| 亚洲日本中文字幕一区二区三区| 一区二区在线播放视频| 日本一区二区在线播放| 无码人妻一区二区三区免费手机 | 亚洲午夜精品第一区二区8050| 国产一区二区高清在线播放| 国产成人AV一区二区三区无码| 亚洲一区二区三区四区视频| 精品无码中出一区二区| 精品国产一区二区三区在线| 一本色道久久综合一区| 色窝窝无码一区二区三区成人网站| 日本一区二区三区爆乳| 中文字幕在线一区| 亚洲高清毛片一区二区| 欧洲精品无码一区二区三区在线播放| 久久精品亚洲一区二区三区浴池| 国产精品一区二区在线观看| 国产精品一区二区久久不卡| 亚洲日韩一区精品射精| 日产一区日产2区| 精品一区狼人国产在线| 亚洲AV福利天堂一区二区三| 精品人妻一区二区三区四区在线 | 一区二区精品久久| 国产精品一区二区久久| 国产伦精品一区二区三区| 立川理惠在线播放一区| 麻豆一区二区免费播放网站|