我的目标是:
- 我将一个人的数据加载到一个模板中,然后发送到我的视图
- 用户可以修改他的数据并点击"提交">
除了图像之外,几乎所有东西都能正常工作。事实上,在我的控制器的方法中,我以数组的字节为单位接收图像,但我不知道如何在视图中显示它。我在网上找到了几个解释,我必须使用URI方案。
但我不知道我的控制器是如何在我的代码js中发送这些数据的。我想说,@Model.Member_Picture的输入恰好包含"value="System.Byte[]".
你能启发我一下吗?
(我只是发布了与图片相关的代码(。
型号
[ContainerDataFor("Picture_gr")] // use the name in your C# model
public byte[] Member_Picture { get; set; }
查看
<div class="form-check-inline col-xs-6" style="margin-top:2%">
<img id="ItemPreview" src="" accept="image/png, image/jpeg"/>
</div>
<div class="form-check-inline col-xs-6" style="margin-top:2%">
@Html.LabelFor(model => model.Member_Picture, "Upload Picture", new { htmlAttributes = new { @id = "test" } })
<input type="file" class="form-control-file" name="file" id="file" value="@Model.Member_Picture">
<small id="fileHelp" class="form-text text-muted">Maximum 1024kb</small>
</div>
$(document).ready(function () {
var img = $('#test').val();
$('#ItemPreview').attr('src', `data:image/png;base64,${img}`);
});
不能在<input type="file" />
中使用value
属性来渲染图像。您需要使用以下设置将图像渲染为Base64字符串:
@{
var base64Image = Convert.ToBase64String(Model.Member_Picture);
var source = String.Format("data:image/png;base64,{0}", base64Image);
}
<img src="@source" width="100%" height="100%" />
或者创建另一个字符串属性,如下所示:
public byte[] Member_Picture { get; set; }
public string Image
{
get
{
return String.Format("data:image/png;base64,{0}", Convert.ToBase64String(Member_Picture));
}
}
并在视图中显示:
<img src="@Model.Image" width="100%" height="100%" />
将src更改为src="data:image/png;base64, +data"
,其中数据是图像的字节数组
<img id="ItemPreview" src="data:image/png;base64, @Model.Member_Picture">
示例
<div>
<img src="" alt="Red dot" />
</div>
你可以用香草Javascript这样做:
var fileInput = document.getElementById('img-input');
var demo = document.getElementById('demo');
fileInput.addEventListener('change', function(e) {
var file = fileInput.files[0];
var imageType = /image.*/;
if (file.type.match(imageType)) {
var reader = new FileReader();
reader.onload = function(e) {
demo.src= e.target.result;
}
reader.readAsDataURL(file);
} else {
demo.src = '';
console.log('file not supported');
}
});
#demo {
margin-top: 20px;
}
#img-input {
background-color: #4CAF50;
border: none;
color: white;
text-align: center;
padding: 12px 20px;
display: inline-block;
font-size: 18px;
margin: 20px auto;
cursor: pointer;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div>
<input type="file" id="img-input" name="file"></div>
<!-- this is where we display the choosen image //-->
<img id="demo" src="#" alt="your image here" />