繁体   English   中英

部分视图和jQuery图形问题

[英]Partial View and jQuery graph issues

我继承了一个项目,关于UI方面非常环保。 该项目在Chrome上使用Bootstrap,nvd3和flot。 有一个布局视图,其中引用了jQuery,然后在布局主体中呈现了每个页面的部分视图。 在仪表板页面上,除非脚本中再次引用jQuery,否则不会显示图形,但是该引用会导致侧边栏停止工作。 可以在仪表板脚本中复制引用缓动,以同时显示图形和侧边栏,但是一个图形仍无法正常工作。 这使我相信jQuery及其库在布局和局部视图上被多次引用,清除了显示图形,激活侧边栏,正确呈现图形的引用等。

如果这是正确的,是否有一种方法可以跟踪每个jQuery参考? 我尝试通过视觉删除源代码中的多个引用,将布局引用移至HTML正文中,测试通过Chrome开发者工具所遭受的打击,如上所述将这些引用作为创可贴进行调用,并在此处搜索类似问题,但似乎无法同时实现正确的外观和功能。 另外,共享相同父布局的不同局部视图上的重复jQuery引用是否可以使其他任何局部视图中的引用无效? 请认为如果这里没有考虑其他可能的解决方案,因为我最终正在尝试使侧边栏和图形正常工作。 在此先感谢您的关注。

这是带有参考的布局:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>@ViewBag.Title</title>
    <meta name="viewport" content="initial-scale=1.0,maximum-scale=1.0,user-scalable=no">

    <link rel="shortcut icon" href="/favicon.ico" />

    @Styles.Render("~/Content/css")
    @Styles.Render("~/Content/icons")

    @Scripts.Render("~/bundles/modernizr")

    @RenderSection("headcontent", required: false)

    <!-- page specific stylesheets -->
    <!-- nvd3 charts -->
    <link rel="stylesheet" href="/Content/lib/novus-nvd3/nv.d3.min.css">
    <!-- owl carousel -->
    <link rel="stylesheet" href="/Content/lib/owl-carousel/owl.carousel.css">

    <!-- google webfonts -->
    <link href='http://fonts.googleapis.com/css?family=Source+Sans+Pro:400&amp;subset=latin-ext,latin' rel='stylesheet' type='text/css'>

    <!-- datepicker -->
    <link rel="stylesheet" href="/Content/lib/bootstrap-datepicker/css/datepicker3.css">
    <!-- date range picker -->
    <link rel="stylesheet" href="/Content/lib/bootstrap-daterangepicker/daterangepicker-bs3.css">
    <!-- timepicker -->
    <link rel="stylesheet" href="/Content/lib/bootstrap-timepicker/css/bootstrap-timepicker.min.css">
    <!-- ion.rangeSlider -->
    <link rel="stylesheet" href="/Content/lib/ion.rangeSlider/css/ion.rangeSlider.css">
    <!-- bootstrap switches -->
    <link href="/Content/lib/bootstrap-switch/build/css/bootstrap3/bootstrap-switch.css" rel="stylesheet">
    <!-- 2col multiselect -->
    <link href="/Content/lib/multi-select/css/multi-select.css" rel="stylesheet">
    <!-- multiselect, tagging -->
    <link rel="stylesheet" href="/Content/lib/select2/select2.css">

    <!-- main stylesheet -->
    <link href="/Content/css/style.css" rel="stylesheet" media="screen">

    <!-- moment.js (date library) -->
    <script src="/Content/lib/moment-js/moment.min.js"></script>


    [styles omitted...]

</head>
<body>
    [header omitted...]

    <!-- main content -->
    <div id="main_wrapper">

        [messages omitted...]

        @RenderBody()
    </div>

    <!-- side navigation -->
    <nav id="side_nav">
        @Html.Partial("~/Views/Shared/_SidebarLeft.cshtml")
    </nav>

    <!-- jQuery -->
    <script src="/Content/js/jquery.min.js"></script>
    <!-- easing -->
    <script src="/Content/js/jquery.easing.1.3.min.js"></script>
    <!-- bootstrap js plugins -->
    <script src="/Content/bootstrap/js/bootstrap.min.js"></script>
    <!-- top dropdown navigation -->
    <script src="/Content/js/tinynav.js"></script>
    <!-- perfect scrollbar -->
    <script src="/Content/lib/perfect-scrollbar/min/perfect-scrollbar-0.4.8.with-mousewheel.min.js"></script>

    <!-- common functions -->
    <script src="/Content/js/tisa_common.js"></script>

    @RenderSection("Scripts", required: false)

</body>
</html>

这是仪表板的HTML:

@using Project.Models
@model DashboardViewModel
@{
    ViewBag.Title = "Home Page";

    Layout = "~/Views/Shared/_Layout.cshtml";
}

<div class="container-fluid">
    <div class="row">
        <div class="col-md-12">
            <div class="panel panel-default">
                <div class="heading_b">Prices Chart</div>
                <div class="panel-body">
                    <div id="nvd3_cumulativeLine" style="width: 100%; height: 300px">
                        <svg></svg>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>

最后,这是仪表板脚本,其中删除了jQuery,导致图表消失,删除了缓动,导致侧栏停止弹出,并且删除了两者,导致图表消失,但侧栏功能保持不变。

@section Scripts{
    <!-- page specific plugins -->

    <!-- jQuery DUPLICATE -->
    <script src="/Content/js/jquery.min.js"></script>
    <!-- easing DUPLICATE -->
    <script src="/Content/js/jquery.easing.1.3.min.js"></script>

    <!-- nvd3 charts -->
    <script src="/Content/lib/d3/d3.min.js"></script>
    <script src="/Content/lib/novus-nvd3/nv.d3.min.js"></script>
    <!-- flot charts-->
    <script src="/Content/lib/flot/jquery.flot.min.js"></script>
    <script src="/Content/lib/flot/jquery.flot.pie.min.js"></script>
    <script src="/Content/lib/flot/jquery.flot.resize.min.js"></script>
    <script src="/Content/lib/flot/jquery.flot.tooltip.min.js"></script>
    <!-- clndr -->
    <script src="/Content/lib/underscore-js/underscore-min.js"></script>
    <script src="/Content/lib/CLNDR/src/clndr.js"></script>
    <!-- easy pie chart -->
    <script src="/Content/lib/easy-pie-chart/dist/jquery.easypiechart.min.js"></script>
    <!-- owl carousel -->
    <script src="/Content/lib/owl-carousel/owl.carousel.min.js"></script>

    <!-- dashboard graph functions -->
    <script src="/Content/js/apps/tisa_dashboard.js"></script>

    <script type="text/javascript">
        function cumulativeTestData() {
            var closes = JSON.parse('@Html.Raw(Json.Encode(Model.Coordinates))')
            return [
                {
                    key: "Prices",
                    values: closes
                },
            ];
        }
    </script>
}

您认为在多次加载同一脚本时存在冲突是正确的。 每个脚本仅加载一次。

我可以看到为什么尝试从部分视图中删除那些脚本导致您的部分视图失败的原因。 直到局部视图之后,您才加载脚本。 在部分视图中的所有内容都已加载并执行之后,它们才存在。

在布局中,将脚本移至标题(首选)或至少移至某个位置,然后再拉入局部视图。 然后在您的局部视图中,确保没有对已加载脚本的引用。

在局部视图中,我经常使用脚本争用程序来加载可能已动态加载或未动态加载的脚本。 您可以使用以下方法来尝试加载脚本。 它检查是否已经在页面上(特别是在标题标记中)加载了具有相同名称的脚本,如果已经加载,则不会尝试再次加载它。 它不是最漂亮的,但是可以完成工作。

mycode = function()
{

    //Put all your custom javascript here.
    //This will run when the scripts below have successfully been processed.

}
var headTag = document.getElementsByTagName("head")[0];
var initialScripts = ["/scripts/jquery-2.1.4.min.js",
                        "/scripts/jquery-ui.min.js",
                        "/scripts/jquery.timepicker.min.js"];
var neededScripts = [];
for (var z = 0; z < initialScripts.length; z++) {
    if (!isScriptLoaded(initialScripts[z]))
        neededScripts.push(initialScripts[z]);
}
if(neededScripts.length)
    addScripts(neededScripts, headTag, function () { mycode(); delete mycode; }, 0);
else {
    mycode(); delete mycode;
}
function addScripts(scriptsToLoad, loadTag, callback, i) {
    if (i >= scriptsToLoad.length)
        return;
    var script = scriptsToLoad[i];
    var scriptTag = document.createElement('script');
    scriptTag.setAttribute('type', 'text/javascript');
    scriptTag.setAttribute('src', script);
    if (i >= (scriptsToLoad.length - 1)) {
        scriptTag.onload = callback;
    }
    else {
        scriptTag.onload = function () {
            console.log("Added script file " + script);
            addScripts(scriptsToLoad, loadTag, callback, i + 1);
        }
    }
    loadTag.appendChild(scriptTag);
}

function isScriptLoaded(url) {
    var tags = document.getElementsByTagName('script');
    for (var i = tags.length; i--;) {
        var existingName = tags[i].src.split('/');
        existingName = existingName[existingName.length-1];

        var newName = url.split('/');
        newName = newName[newName.length-1];

        if (existingName == newName) return true;
    }
    return false;
}

暂无
暂无

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

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