当前位置: 移动技术网 > IT编程>开发语言>c# > C#计算两个文件的相对目录算法的实例代码

C#计算两个文件的相对目录算法的实例代码

2019年07月18日  | 移动技术网IT编程  | 我要评论
楼主大菜鸟一只,第一次写技术博客,如果有概念错误或代码不规范的地方,还请各位多多批评指正。话不多说,来看题: 前一阵子开发了一个用户控件,里面调用了很多css,js等资源

楼主大菜鸟一只,第一次写技术博客,如果有概念错误或代码不规范的地方,还请各位多多批评指正。话不多说,来看题:

前一阵子开发了一个用户控件,里面调用了很多css,js等资源文件,而引用控件的页面所在目录是不同的。问题出来了:如果目录不同,那么控件里引用css,js资源文件的路径也会相应变化。现在已知两个文件相对于网站根目录的路径,如何计算相对路径呢?请看代码:

复制代码 代码如下:

public string getrelativepath(string path1, string path2)
{
            string[] path1array = path1.split('/');
            string[] path2array = path2.split('/');
            //
            int s = path1array.length >= path2array.length ? path2array.length : path1array.length;
            //两个目录最底层的共用目录索引
            int closestrootindex = -1;
            for (int i = 0; i < s; i++)
            {
                if (path1array[i] == path2array[i])
                {
                    closestrootindex = i;
                }
                else
                {
                    break;
                }
            }
            //由path1计算 ‘../'部分
            string path1depth = "";
            for (int i = 0; i < path1array.length; i++)
            {
                if (i > closestrootindex + 1)
                {
                    path1depth += "../";
                }
            }
            //由path2计算 ‘../'后面的目录
            string path2depth = "";
            for (int i = closestrootindex + 1; i < path2array.length; i++)
            {
                path2depth += "/" + path2array[i];
            }
            path2depth = path2depth.substring(1);

            return path1depth + path2depth;
}

我的算法,第一步算出两个目录的最底层父目录,第二步算出目录1需要向上级目录返回次数(../个数),第三步算出最底层父目录到目录2的相对路径,第四步把第二步和第三步的结果相加就是我们要的答案了。

调用部分:

复制代码 代码如下:

string path1 = "/manage/permissions/rolemanage.aspx";
string path2 = "/manage/plugin/jquery-easyui/jquery.easyui.min.js";
string result = getrelativepath(path1, path2);

得到结果:../plugin/jquery-easyui/jquery.easyui.min.js

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网