0

0

在 C# NET 代码库中实现 Bootstrap 现代化:来自 o 5 的 Python 支持的迁移

王林

王林

发布时间:2024-07-22 17:31:13

|

1016人浏览过

|

来源于dev.to

转载

在 c# net 代码库中实现 bootstrap 现代化:来自 o 5 的 python 支持的迁移

介绍

作为一名开发人员,我最近发现自己面临着一个令人兴奋的挑战:对仍在使用 bootstrap 3 的旧版 c# .net 代码库进行现代化改造。目标很明确 - 使用最新的 bootstrap 5 加快项目速度。但是,我很快就意识到实现如此重大的飞跃可能会充满风险且耗时。

就在那时我决定采取分阶段的方法:

  1. 首先,从 bootstrap 3 迁移到 bootstrap 4
  2. 然后,一旦稳定,就从 bootstrap 4 跳转到 bootstrap 5

此策略将允许更易于管理的转换、更容易的调试以及更流畅的整体过程。今天,我很高兴分享这个旅程的第一部分 - 使用 python 脚本自动从 bootstrap 3 迁移到 4。

关于代码的注释

在深入研究之前,请务必注意,此处提供的代码是项目中使用的实际脚本的简化版本。出于明显的原因,例如专有信息和特定项目要求,我简化了这篇博文的代码。然而,该方法和核心功能仍然与现实场景中实现的非常相似。

立即学习Python免费学习笔记(深入)”;

挑战

从 bootstrap 3 迁移到 4 涉及大量类名更改和弃用的组件。在整个项目中手动更新这些内容可能非常耗时且容易出错。这就是我们的 python 脚本的用武之地。

解决方案

我们的脚本(我们将其称为 bootstrap_migrator.py)旨在扫描您的项目文件并自动将 bootstrap 3 类名称更新为 bootstrap 4 的等效名称。它可以处理 html、razor (cshtml) 甚至 javascript 文件,使其成为满足您的迁移需求的全面解决方案。

分解代码

让我们深入了解迁移脚本的详细信息并解释每个部分。

导入所需的模块

import os
import re

我们首先导入两个基本的 python 模块:

  • os:此模块提供了一种使用操作系统相关功能的方法,例如导航文件系统。
  • re: 该模块提供了对python中正则表达式的支持。

主要迁移功能

def update_bootstrap_classes(content, file_type):
    class_mappings = {
    r'\bcol-xs-(\d+)\b': r'col-\1',
    r'\bcol-sm-(\d+)\b': r'col-sm-\1',
    r'\bcol-md-(\d+)\b': r'col-md-\1',
    r'\bcol-lg-(\d+)\b': r'col-lg-\1',
    r'\bcol-xl-(\d+)\b': r'col-xl-\1',
    r'\bbtn-default\b': 'btn-secondary',
    r'\bimg-responsive\b': 'img-fluid',
    r'\bimg-circle\b': 'rounded-circle',
    r'\bimg-rounded\b': 'rounded',
    r'\bpanel\b': 'card',
    r'\bpanel-heading\b': 'card-header',
    r'\bpanel-title\b': 'card-title',
    r'\bpanel-body\b': 'card-body',
    r'\bpanel-footer\b': 'card-footer',
    r'\bpanel-primary\b': 'card bg-primary text-white',
    r'\bpanel-success\b': 'card bg-success text-white',
    r'\bpanel-info\b': 'card text-white bg-info',
    r'\bpanel-warning\b': 'card bg-warning',
    r'\bpanel-danger\b': 'card bg-danger text-white',
    r'\bwell\b': 'card card-body',
    r'\bthumbnail\b': 'card card-body',
    r'\blist-inline\s*>\s*li\b': 'list-inline-item',
    r'\bdropdown-menu\s*>\s*li\b': 'dropdown-item',
    r'\bnav\s+navbar\s*>\s*li\b': 'nav-item',
    r'\bnav\s+navbar\s*>\s*li\s*>\s*a\b': 'nav-link',
    r'\bnavbar-right\b': 'ml-auto',
    r'\bnavbar-btn\b': 'nav-item',
    r'\bnavbar-fixed-top\b': 'fixed-top',
    r'\bnav-stacked\b': 'flex-column',
    r'\bhidden-xs\b': 'd-none',
    r'\bhidden-sm\b': 'd-sm-none',
    r'\bhidden-md\b': 'd-md-none',
    r'\bhidden-lg\b': 'd-lg-none',
    r'\bvisible-xs\b': 'd-block d-sm-none',
    r'\bvisible-sm\b': 'd-none d-sm-block d-md-none',
    r'\bvisible-md\b': 'd-none d-md-block d-lg-none',
    r'\bvisible-lg\b': 'd-none d-lg-block d-xl-none',
    r'\bpull-right\b': 'float-right',
    r'\bpull-left\b': 'float-left',
    r'\bcenter-block\b': 'mx-auto d-block',
    r'\binput-lg\b': 'form-control-lg',
    r'\binput-sm\b': 'form-control-sm',
    r'\bcontrol-label\b': 'col-form-label',
    r'\btable-condensed\b': 'table-sm',
    r'\bpagination\s*>\s*li\b': 'page-item',
    r'\bpagination\s*>\s*li\s*>\s*a\b': 'page-link',
    r'\bitem\b': 'carousel-item',
    r'\bhelp-block\b': 'form-text',
    r'\blabel\b': 'badge',
    r'\bbadge\b': 'badge badge-pill'
}

这个函数是我们脚本的核心。它需要两个参数:

星月写作
星月写作

专为网络小说、 剧本创作者打造的AI增效工具

下载
  • content:我们正在更新的文件的内容。
  • file_type:我们正在处理的文件类型(html、js 等)。

class_mappings 字典至关重要。它将 bootstrap 3 类模式(作为正则表达式)映射到 bootstrap 4 的等效项。例如,col-xs-* 在 bootstrap 4 中变成了 col-*。

替换 html 和 razor 文件中的类

def replace_class(match):
    classes = match.group(1).split()
    updated_classes = []
    for cls in classes:
        replaced = false
        for pattern, replacement in class_mappings.items():
            if re.fullmatch(pattern, cls):
                updated_cls = re.sub(pattern, replacement, cls)
                updated_classes.append(updated_cls)
                replaced = true
                break
        if not replaced:
            updated_classes.append(cls)
    return f'class="{" ".join(updated_classes)}"'

if file_type in ['cshtml', 'html']:
    return re.sub(r'class="([^"]*)"', replace_class, content)

这部分处理 html 和 razor 文件中类的替换:

  1. 它找到 html 中的所有类属性。
  2. 对于找到的每个类,它会检查它是否与我们的 bootstrap 3 模式中的任何一个匹配。
  3. 如果找到匹配项,它将用 bootstrap 4 的等效类替换该类。
  4. 不匹配任何模式的类保持不变。

更新 javascript 选择器

    def replace_js_selectors(match):
        full_match = match.group(0)
        method = match.group(1)
        selector = match.group(2)

        classes = re.findall(r'\.[-\w]+', selector)

        for i, cls in enumerate(classes):
            cls = cls[1:]  
            for pattern, replacement in class_mappings.items():
                if re.fullmatch(pattern, cls):
                    new_cls = re.sub(pattern, replacement, cls)
                    classes[i] = f'.{new_cls}'
                    break

        updated_selector = selector
        for old_cls, new_cls in zip(re.findall(r'\.[-\w]+', selector), classes):
            updated_selector = updated_selector.replace(old_cls, new_cls)

        return f"{method}('{updated_selector}')"

    if file_type == 'js':
        js_jquery_methods = [
            'queryselector', 'queryselectorall', 'getelementbyid', 'getelementsbyclassname',
            '$', 'jquery', 'find', 'children', 'siblings', 'parent', 'closest', 'next', 'prev',
            'addclass', 'removeclass', 'toggleclass', 'hasclass'
        ]

        method_pattern = '|'.join(map(re.escape, js_jquery_methods))
        content = re.sub(rf"({method_pattern})\s*\(\s*['\"]([^'\"]+)['\"]\s*\)", replace_js_selectors, content)

        return content

本节处理更新 javascript 文件中的类名:

  1. 它定义了可能使用类选择器的常见 javascript 和 jquery 方法的列表。
  2. 然后使用正则表达式查找这些方法调用并更新其选择器中的类名称。
  3. 它还更新了 jquery 的 .css() 方法调用中使用的类名。

处理单个文件

def process_file(file_path):
    try:
        with open(file_path, 'r', encoding='utf-8') as file:
            content = file.read()

        file_type = file_path.split('.')[-1].lower()
        updated_content = update_bootstrap_classes(content, file_type)

        if content != updated_content:
            with open(file_path, 'w', encoding='utf-8') as file:
                file.write(updated_content)
            print(f"updated: {file_path}")
        else:
            print(f"no changes: {file_path}")
    except exception as e:
        print(f"error processing {file_path}: {str(e)}")

此函数处理单个文件的处理:

  1. 它读取文件的内容。
  2. 根据扩展名确定文件类型。
  3. 调用update_bootstrap_classes更新内容。
  4. 如果进行了更改,它将更新的内容写回到文件中。
  5. 它还处理异常并提供流程反馈。

主要功能

def main():
    project_dir = input("enter the path to your project directory: ")
    print(f"scanning directory: {project_dir}")

    if not os.path.exists(project_dir):
        print(f"the directory {project_dir} does not exist.")
        return

    files_found = false
    for root, dirs, files in os.walk(project_dir):
        for file in files:
            if file.endswith(('.cshtml', '.html', '.js')):
                files_found = true
                file_path = os.path.join(root, file)
                print(f"processing file: {file_path}")
                process_file(file_path)

    if not files_found:
        print("no .cshtml, .html, or .js files found in the specified directory.")

if __name__ == "__main__":
    main()

主要功能将所有内容联系在一起:

  1. 它提示用户输入项目目录。
  2. 然后它会遍历目录,查找所有相关文件(.cshtml、.html、.js)。
  3. 对于找到的每个文件,它都会调用 process_file 来更新其内容。
  4. 它提供有关过程的反馈,包括是否未找到相关文件。

主要特征

  • 全面的类更新:从网格类到特定于组件的类,脚本涵盖了广泛的 bootstrap 更改。
  • javascript 支持:它更新各种 javascript 和 jquery 选择器中的类名称,确保您的动态内容不会中断。
  • 灵活性:脚本可以轻松扩展以包含更多类映射或文件类型。
  • 非破坏性:它只修改需要更改的文件,而不影响其他文件。

使用脚本

要使用该脚本,只需运行它并在出现提示时提供项目目录的路径即可。然后它将处理所有相关文件,并根据需要更新它们。

python bootstrap_migrator.py

限制和注意事项

虽然此脚本自动执行了迁移过程的很大一部分,但值得注意的是,它不是一个完整的解决方案。你仍然应该:

  1. 运行脚本后彻底测试您的应用程序。
  2. 注意 bootstrap 4 可能需要手动实现的新组件和功能。
  3. 检查可能与 bootstrap 类交互的自定义​​ css 和 javascript。

结论

此脚本提供了一种强大的自动化方法来处理 bootstrap 3 到 4 迁移过程的大部分,从而节省开发人员大量时间并减少手动错误的机会。它代表了我们对遗留 c# .net 代码库进行现代化改造的第一步。一旦我们成功迁移到 bootstrap 4 并确保稳定性,我们将处理下一阶段:从 bootstrap 4 迁移到 5。

请记住,虽然自动化非常有用,但它并不能替代理解 bootstrap 版本之间的变化。使用此脚本作为迁移过程中的强大帮助,但始终将其与您的专业知识和彻底的测试结合起来。

迁移快乐!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

405

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

515

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

312

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

128

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

183

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

51

2026.01.13

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号