C# Linq操作List或数组

本文介绍了使用Linq进行数组操作的方法,包括合并、去重、排序、求交集及差集等操作。通过示例代码展示了如何实现这些功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Linq对数组操作分为合并、交集、差集等。

List<int> numbers1 = new List<int>() { 1, 3, 5 };
List<int> numbers2 = new List<int>() { 3,5,11, 13, 15 };

//合并排序
var newList = numbers1.Concat(numbers2).OrderBy(n => n);
foreach (var item in newList)
{
    Console.WriteLine(item);
}

//合并数组,并去除重复,排序
var newList = numbers1.Concat(from n in numbers2 where !numbers1.Contains(n) select n).OrderBy(n => n);
foreach (var item in newList)
{
    Console.WriteLine(item);
}

//合并,去重,排序
var newList = numbers1.Union(numbers2).OrderBy(n => n);
foreach (var item in newList)
{
    Console.WriteLine(item);
}

//取两个数组交集,排序
var newList = numbers1.Intersect(numbers2).OrderBy(n => n);
foreach (var item in newList)
{
    Console.WriteLine(item);
}

//取出数组1与数组2的差集,排序
var newList = numbers1.Except(numbers2).OrderBy(n => n);
foreach (var item in newList)
{
    Console.WriteLine(item);
}

//判断两个数组是否有交集
var exists = numbers1.Exists(delegate(int n)
{
    return numbers2.Exists(delegate(int i)
    {
        if (n == i)
            return true;
        else return false;
    });
});
Console.WriteLine(exists); 


在若依(Ruoyi框架中,菜单配置和路由参数的设置是非常重要的环节。以下是详细的步骤和注意事项: ### 1. 菜单配置 若依的菜单配置通常在数据库中进行,具体表为 `sys_menu`。在配置菜单时,需要注意以下几个字段: - `menu_name`:菜单名称 - `parent_id`:父级菜单ID - `order_num`:菜单顺序 - `path`:路由路径 - `component`:组件路径 - `perms`:权限标识 - `icon`:菜单图标 - `type`:菜单类型(目录、菜单、按钮) ### 2. 路由参数设置 在若依中,路由参数通常在 `path` 和 `component` 字段中设置。假设我们有一个菜单项需要跳转到某个页面,并且需要传递一些参数,可以按照以下步骤进行配置: #### 示例配置 假设我们要配置一个菜单项,路径为 `/example`,组件为 `example.vue`,并且需要传递一个参数 `id`。 1. **数据库配置**: ```sql INSERT INTO `sys_menu` (`menu_name`, `parent_id`, `order_num`, `path`, `component`, `perms`, `icon`, `type`) VALUES ('示例菜单', 0, 1, 'example', 'example', 'example:view', 'example', 1); ``` 2. **前端配置**: 在 `src/router/index.js` 中配置路由: ```javascript { path: 'example', name: 'Example', component: () => import('@/views/example/index.vue'), meta: { title: '示例菜单', icon: 'example' }, props: route => ({ id: route.query.id }) } ``` 3. **传递参数**: 在前端页面中,可以通过路由参数传递 `id`。例如,在菜单点击事件中: ```javascript this.$router.push({ path: '/example', query: { id: 123 } }); ``` ### 3. 页面接收参数 在 `example.vue` 页面中,可以通过 `props` 接收参数: ```vue <template> <div> <h1>示例页面</h1> <p>接收到的参数:{{ id }}</p> </div> </template> <script> export default { props: ['id'], mounted() { console.log('接收到的参数:', this.id); } } </script> ``` ### 注意事项 - 确保 `path` 和 `component` 字段正确配置。 - 使用 `props` 接收参数时,确保前后端配置一致。 - 传递参数时,可以通过 `query` 或 `params` 进行传递,具体根据需求选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值