zoukankan      html  css  js  c++  java
  • 在Asp.Net Core MVC 开发过程中遇到的问题

    1. Q: Razor视图中怎么添加全局模型验证消息

    A:使用ModelOnly

    <div asp-validation-summary="ModelOnly" class="text-danger"></div>
    

    2.Q:树形表格,使用的是bootstrap-table+jquery.treegrid

    A:

    效果

    参考的代码,某些地方添加了注释

    <link href="https://cdnjs.cloudflare.com/ajax/libs/jquery-treegrid/0.2.0/css/jquery.treegrid.min.css" rel="stylesheet">
    <link href="https://unpkg.com/bootstrap-table@1.15.5/dist/bootstrap-table.min.css" rel="stylesheet">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-treegrid/0.2.0/js/jquery.treegrid.min.js"></script>
    <script src="https://unpkg.com/bootstrap-table@1.15.5/dist/bootstrap-table.min.js"></script>
    <script src="https://unpkg.com/bootstrap-table@1.15.5/dist/extensions/treegrid/bootstrap-table-treegrid.min.js"></script>
    <table id="table"></table>
    <script>
      var $table = $('#table')
      $(function() {
        $table.bootstrapTable({
          url: 'json/treegrid.json',
          striped: true,
          sidePagination: 'server',
          idField: 'id',
          showColumns: true,
          columns: [
            {
              field: 'ck',
              checkbox: true
            },
            {
              field: 'name',
              title: '名称'
            },
            {
              field: 'status',
              title: '状态',
              sortable: true,
              align: 'center',
              formatter: 'statusFormatter'
            },
            {
              field: 'permissionValue',
              title: '权限值'
            }
          ],
          treeShowField: 'name',//注意
          parentIdField: 'pid',//注意
          onPostBody: function() {
            var columns = $table.bootstrapTable('getOptions').columns
    
            if (columns && columns[0][1].visible) {
              $table.treegrid({
                treeColumn: 1,
                onChange: function() {
                  $table.bootstrapTable('resetWidth')
                }
              })
            }
          }
        })
      })
      
      function statusFormatter(value, row, index) {
        if (value === 1) {
          return '<span class="label label-success">正常</span>'
        }
        return '<span class="label label-default">锁定</span>'
      }
    </script>
    

    给复选框添加选择的点击功能,在一个表格中选中一行时,加载与此行有关的数据信息。其他的相关js的引用请自行添加

    $RoleTable.on('check.bs.table uncheck.bs.table ' +
        'check-all.bs.table uncheck-all.bs.table',
        function () {
            $('#RoleToNavi').prop('disabled', !$RoleTable.bootstrapTable('getSelections').length);
            $.map($RoleTable.bootstrapTable('getSelections'),
                function (row) {
                   roleId = row.Id;
                   $RoleNavigationTable.bootstrapTable('destroy');//销毁                    
                   $RoleNavigationTable.bootstrapTable({//重新加载                                                
                });
           });
     });
    

    3.Q:Razor中定义函数~~~~

    A:使用@function

    4.Q:EFCore中怎么设定decimal的精度,如果不设置精度的话,默认生成数据库(MariaDB)中默认精度是(65,30)

    A:设置固定精度问题,示例代码如下

    public class MyProjectContext : DbContext
    {
       public DbSet<order> Orders { get; set; }
    
       rotected override void OnModelCreating(DbModelBuilder modelBuilder)
       {
          base.OnModelCreating(modelBuilder);
          modelBuilder.Entity<order>(b =&gt;
          {
           //配置订单的金额浮点数精度为decimal(18,6)
              b.Property(p =&gt; p.Amount).HasColumnType("decimal(18,6)");
          });   
      }   
    }
    

    5.Q:WPF问题:mvvm模式下,怎么让点击按钮关闭窗口

    A: 使用带参数的Command进行实现,具体代码如下:

    //command定义
    public ICommand CancelCommand { get; set; }
    
    // CancelCommand实现
    CancelCommand = new RelayCommand<window>((window)=&gt;
    {
        window.Close();
    });
    
    xaml:代码
    <window x:class="MvvmCloseWindowApp.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:MvvmCloseWindowApp" mc:ignorable="d" name="MWindow" title="MainWindow" height="350" width="525">
        <grid>
            <button content="Close Window" width="100" height="25" command="{Binding CancelCommand}" commandparameter="{Binding ElementName=MWindow}">
        
    
                
    

    6.Q:asp.net core mvc 将ViewBag中的数据在js中调用/在razor页面中的js代码调用razor变量

    A:假设Action传递到Razor View页面一个参数:ViewBag.Title,在JS中使用这个数据的话需要这样用'@ViewBag.Title',就是在@ViewBag.Title两边加上引号,使用单引号或双引号,这两个都可以

    可以使用 @param,对于要获取的字符串,需要加引号,如'@param,最好都加上引号,因为你不知道js引用后到底是什么类型的数据

    7.Q:使用了Nigix代理后,在使用wpf客户端post方法提交数据时,出现如下错误:

    
    <title>413 request Entity Too Large</title>
    
    <center><h1>413 Request Entity Too Large</h1></center>
    <hr><center>nginx/1.10.3</center>
    
    
    

    A:在nigix的配置文件中http{}内添加如下内容:

    #设置允许发布内容为8M
    client_max_body_size 8M;
    client_body_buffer_size 128k;
    

    针对post
    针对post请求解决办法: 
    修改nginx.conf里面的几个相关的配置参数 
    client_body_buffer_size 10m(配置请求体缓存区大小, 不配的话) 
    client_max_body_size 20m(设置客户端请求体最大值) 
    client_body_temp_path /data/temp (设置临时文件存放路径。只有当上传的请求体超出缓存区大小时,才会写到临时文件中,注意临时路径要有写入权限) 
    如果上传文件大小超过client_max_body_size时,会报413 entity too large的错误。 
    针对get
    针对get请求,我们可以通过修改另外两个配置来解决请求串超长的问题: ~~~~
    client_header_buffer_size 语法:client_header_buffer_size size 默认值:1k 使用字段:http, server 这个指令指定客户端请求的http头部缓冲区大小绝大多数情况下一个头部请求的大小不会大于1k不过如果有 来自于wap客户端的较大的cookie它可能会大于1k,Nginx将分配给它一个更大的缓冲区,这个值可以在 large_client_header_buffers里面设置。 large_client_header_buffers 语法:large_client_header_buffers number size 默认值:large_client_header_buffers 4 4k/8k 使用字段:http, server 指令指定客户端请求的一些比较大的头文件到缓冲区的最大值,如果一个请求的URI大小超过这个值,服务 器将返回一个"Request URI too large" (414),同样,如果一个请求的头部字段大于这个值,服务器 将返回"Bad request" (400)。 缓冲区根据需求的不同是分开的。 默认一个缓冲区大小为操作系统中分页文件大小,通常是4k或8k,如果一个连接请求将状态转换为 keep-alive,这个缓冲区将被释放。
    为什么修改http header的大小就能解决get请求串过长的问题?因为get请求参数会拼在http header中,所以,修改了http header的大小,就能解决上面问题。

    8.Q:使用layx弹窗时,如果给父页面传递数据

    A:请看例子,示例是在layer例子中看到的

    父页面的js代码,其中父页面中包含一个名为IconInput

    <script type="text/javascript">
        $('#IconBtn').on('click',//绑定IconBtn按钮的点击事件,弹出layx窗口
            function () {
                layx.iframe('icon', '请选择图标', '/Icon/FontAwesomeIcon');//加载一个图标选择页面
                return false;//放在提交数据
            });
    </script>
    

    FontAwesomeIcon页面中使用js代码,使用parent可以获取父页面上的属性值并给它们赋值

    $('#IconSaveBtn').on('click',//绑定IconSaveBtn按钮的点击事件,将选择的数据传到到父窗口
       function () {
          parent.$('#Icon').val($pickIcon.attr('class'));
          parent.layx.destroy('icon');
       });
    

    如果可以,需要你的一个关注!!

  • 相关阅读:
    集合的泛型
    Strom的集群停止以及启动
    Strom简介,以及安装,和官方案例测试
    089实战 Nginx的安装
    088实战 项目技术框架
    087实战 集群的规模
    086实战 项目开发流程,以及什么是数据分析平台,再者为什么要做数据分析平台,数据来源,数据处理流程
    085 HBase的二级索引,以及phoenix的安装(需再做一次)
    084 HBase的数据迁移(含HDFS的数据迁移)
    083 HBase的完全分布式的搭建与部署,以及多master
  • 原文地址:https://www.cnblogs.com/sesametech-netcore/p/11989547.html
Copyright © 2011-2022 走看看