简体   繁体   English

使用 ajax 加载视图组件时,视图组件 javaScript 代码不起作用

[英]when using ajax to load a view component the view components javaScript Codes doesn't work

i used a view Component that has some javaScript codes for animations.我使用了一个视图组件,其中包含一些用于动画的 JavaScript 代码。 when page loaded javaScript works well but when click a button to load data with ajax, data loaded correctly but javaScript codes doesn't work any more当页面加载 javaScript 运行良好但单击按钮以使用 ajax 加载数据时,数据正确加载但 javaScript 代码不再工作

// in view component code // 在视图组件代码中

   public async Task<IViewComponentResult> InvokeAsync(GalleryInvokeParameterViewModel par)
    {
    var gallery = await _productService.GetGalleriesForSingleProductAsync(par.ProductID,par.ColorID);
    ViewBag.mainImage = await _productService.GetMainImageGalleryForSingleProductAsync(par.ProductID, par.ColorID);
    ViewBag.productId = par.ProductID;
    return View("SingleProductGallery",gallery);
    }

// in controller // 在控制器中

    public IActionResult ChangeGallery(int id, int colorId)
{
var parameters = new GalleryInvokeParameterViewModel
{
ColorID = colorId,
ProductID = id
};
return ViewComponent("SingleProductGallery", parameters);
}

// in javascript codes for ZOOM image ON HOVER IMAGE // these codes doesn't work after calling ajax to load data // 在 HOVER IMAGE 上缩放图像的 javascript 代码中 // 这些代码在调用 ajax 加载数据后不起作用

    var zoomArea = document.getElementById("zoom-area");
var zoomImage = document.getElementById("zoom-image");
zoomArea.addEventListener("mousemove", function (event) {
var clientX = event.clientX - zoomArea.offsetLeft;
var clientY = event.clientY - zoomArea.offsetTop;
var aWidth = zoomArea.offsetWidth;
var aHeight = zoomArea.offsetHeight;
clientX = (clientX / aWidth) * 100;
clientY = (clientY / aHeight) * 100;
zoomImage.style.transform =
"translate(-" + clientX + "% , -" + clientY + "%) scale(1.5)";
});
$(zoomArea).mouseleave(function () {
zoomImage.style.transform = "translate(-50% , -50%) scale(1)";
});

i found a solution for this issue.我找到了解决这个问题的方法。 after ajax called and returned data i call :在ajax调用并返回数据后我调用:

        $(document).ajaxComplete(function () {js code});

and it reloaded javaScript codes again and my animations code works well.它再次重新加载了 JavaScript 代码,我的动画代码运行良好。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM