Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

dotNet: dataGridView + dataTable въпрос.

Featured Replies

Останал съм с впечатлението, че имаше отделна тема за dotNet програмиране, но не я намирам.

Ето какво ме интересува. Свързано е с dotNet.

"system.windows.forms.dataGridView"  по подразбиране може да изобрази само 655 колони. Причината е, че свойството FillWeight за всяка отделна колона, пак по подразбиране, е със стойност 100. Когато се зададе създаване на 1000 колони например излиза подобно съобщение:

Цитат

.NET runtime exception: Sum of the columns' FillWeight values cannot exceed 65535.

Тази стойност 65535 е 2 на 16 степен(65536). Като се раздели на FillWeight = 100 и се получава това ограничение от 655 колони в dataGridView. Решението е да се зададе FillWeight = 1. И това решение работи.

Обаче има един сериозен проблем със скоростта на работа на dataGridView - бавно е при много колони и редове. И самото попълване на клетките с информация е бавно, и превъртането по вертикала и хоризонтала е бавно.

И този проблем си има решение. Може да се използва "system.Data.DataTable", която да се "напълни" с желаната информация и след това да се "подаде" на dataGridView.

("system.windows.forms.dataGridView").DataSource = "system.Data.DataTable".

По този начин зареждането на цялата информация е много по-бързо както и самата навигация след това.От тестовете, който направих, за да се създадат  102 колони и 80 реда с необходимата информация:

чист dataGridView - над 1 секунда

dataTable(("system.windows.forms.dataGridView").DataSource = "system.Data.DataTable") - под 0,2 секунди

dataGridView предлага доста възможности за персонализация - може да се променя цвета на цяла колона, на отделни клетки, да се замразяват и преоразмеряват колони, клетки да се задават като "read only" и т.н.

в dataTablе обаче така и не намирам как може да се правят подобни неща. Най-належащо ми е да мога да замразявам колони.

При dataGridVeiw е лесно: col.frozen=true и желаната колона не се скрива при хоризонтално превъртане на останалите колони.

Как да се направи същото, когато се използва dataTable?

Там колоните ги създавам по следният начин:

dataTable.columns.add "Text" (dotnet.getType "System.String")

 

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.