добавление данных
добавление и удаление данных программно
сортировка
связывание элемента управления с базой данных
заполняем элемент данными из разных источников данных
программно подогнать ширину элемента под текст
автоматическая прокрутка списка при добавлении элемента
добавление и удаление данных программно
сортировка
связывание элемента управления с базой данных
заполняем элемент данными из разных источников данных
программно подогнать ширину элемента под текст
автоматическая прокрутка списка при добавлении элемента
добавление данных
Добавить данные можно с помощью диалогового окна или конструктора формы.
Выберите свойство Items и нажмите на кнопку или раскройте треугольник в элементе и нажмите на Edit Items, появится диалоговое окно, где можно добавить данные.
Выберите свойство Items и нажмите на кнопку или раскройте треугольник в элементе и нажмите на Edit Items, появится диалоговое окно, где можно добавить данные.
data:image/s3,"s3://crabby-images/e6f91/e6f914d42b497f750a5b47c9002f4cd338da6e96" alt=""
Form1.cs
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
WindowsFormsApplication1 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
}
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
textBox1.Text +=
" "
+ listBox1.Text +
"\r\n"
;
-
}
-
}
}
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
WindowsFormsApplication1 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
}
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
textBox1.Text +=
" "
+ listBox1.Text +
"\r\n"
;
-
}
-
}
}
data:image/s3,"s3://crabby-images/77038/77038e574ed603c22cd1114fa15a4921fb9c9357" alt=""
добавление и удаление данных программно
Form1.cs
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0042 {
-
public
partial
class
Form1 : Form {
-
//промежуточное свойство, которому будут передаваться данные из дочерней формы
-
public
ListBox Between {
-
set
{
-
listBox1.Items.Add(value);
-
}
-
get
{
-
return
listBox1;
-
}
-
}
-
public
Form1() {
-
InitializeComponent();
-
}
-
//кнопка Добавить
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
//открываем дочернюю форму и передаем ей ссылку
-
new
Form2().ShowDialog(
this
);
-
}
-
//кнопка Удалить
-
private
void
button2_Click(
object
sender, EventArgs e) {
-
listBox1.Items.Remove(listBox1.SelectedItem);
-
}
-
//кнопка Удалить все
-
private
void
button3_Click(
object
sender, EventArgs e) {
-
listBox1.Items.Clear();
-
}
-
//кнопка OK
-
private
void
button4_Click(
object
sender, EventArgs e) {
-
textBox1.Text +=
" "
+ listBox1.Text +
"\r\n"
;
-
}
-
//кнопка Clear
-
private
void
button5_Click(
object
sender, EventArgs e) {
-
textBox1.Clear();
-
}
-
}
}
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0042 {
-
public
partial
class
Form1 : Form {
-
//промежуточное свойство, которому будут передаваться данные из дочерней формы
-
public
ListBox Between {
-
set
{
-
listBox1.Items.Add(value);
-
}
-
get
{
-
return
listBox1;
-
}
-
}
-
public
Form1() {
-
InitializeComponent();
-
}
-
//кнопка Добавить
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
//открываем дочернюю форму и передаем ей ссылку
-
new
Form2().ShowDialog(
this
);
-
}
-
//кнопка Удалить
-
private
void
button2_Click(
object
sender, EventArgs e) {
-
listBox1.Items.Remove(listBox1.SelectedItem);
-
}
-
//кнопка Удалить все
-
private
void
button3_Click(
object
sender, EventArgs e) {
-
listBox1.Items.Clear();
-
}
-
//кнопка OK
-
private
void
button4_Click(
object
sender, EventArgs e) {
-
textBox1.Text +=
" "
+ listBox1.Text +
"\r\n"
;
-
}
-
//кнопка Clear
-
private
void
button5_Click(
object
sender, EventArgs e) {
-
textBox1.Clear();
-
}
-
}
}
Form2.cs
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0042 {
-
public
partial
class
Form2 : Form {
-
public
Form2() {
-
InitializeComponent();
-
}
-
//кнопка OK
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
/*создаем переменную родительской формы (Form1)и присваиваем
-
ей значение через ссылку на родительскую форму*/
-
Form1 F1 = (Form1)
this
.Owner;
-
//присваиваем значение свойству в родительской форме
-
F1.Between.Items.Add(textBox1.Text);
-
//очищаем поле ввода
-
textBox1.Clear();
-
//передаем фокус
-
textBox1.Select();
-
}
-
//кнопка Close
-
private
void
button2_Click(
object
sender, EventArgs e) {
-
this
.Close();
-
}
-
private
void
textBox1_KeyPress(
object
sender, KeyPressEventArgs e) {
-
if
(e.KeyChar == (
char
)Keys.Enter) {
-
//после нажатия клавиши Enter активируем кнопку OK
-
button1.Select();
-
//перехватываем нажатие клавиши, удаляем системный звук
-
e.Handled =
true
;
-
}
-
}
-
}
}
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0042 {
-
public
partial
class
Form2 : Form {
-
public
Form2() {
-
InitializeComponent();
-
}
-
//кнопка OK
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
/*создаем переменную родительской формы (Form1)и присваиваем
-
ей значение через ссылку на родительскую форму*/
-
Form1 F1 = (Form1)
this
.Owner;
-
//присваиваем значение свойству в родительской форме
-
F1.Between.Items.Add(textBox1.Text);
-
//очищаем поле ввода
-
textBox1.Clear();
-
//передаем фокус
-
textBox1.Select();
-
}
-
//кнопка Close
-
private
void
button2_Click(
object
sender, EventArgs e) {
-
this
.Close();
-
}
-
private
void
textBox1_KeyPress(
object
sender, KeyPressEventArgs e) {
-
if
(e.KeyChar == (
char
)Keys.Enter) {
-
//после нажатия клавиши Enter активируем кнопку OK
-
button1.Select();
-
//перехватываем нажатие клавиши, удаляем системный звук
-
e.Handled =
true
;
-
}
-
}
-
}
}
data:image/s3,"s3://crabby-images/0ad96/0ad96f396588447ba7f42c55535be2c2392a6a4a" alt=""
сортировка
Если задать свойству Sorted значение true, данные будут отсортированы, а вот после того, как данные будут отсортированы, задать свойству Sorted значение false, то данные первоначальный несортированный вид, ПОЧЕМУ-ТО не принимают.
Form1.cs
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0043 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
}
-
//флажок
-
private
void
checkBox1_CheckedChanged(
object
sender, EventArgs e) {
-
listBox1.Sorted =
true
;
-
}
-
//кнопка ОК
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
textBox1.Text +=
" "
+ listBox1.SelectedItem +
"\r\n"
;
-
}
-
//кнопка Clear
-
private
void
button2_Click(
object
sender, EventArgs e) {
-
textBox1.Clear();
-
}
-
}
}
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0043 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
}
-
//флажок
-
private
void
checkBox1_CheckedChanged(
object
sender, EventArgs e) {
-
listBox1.Sorted =
true
;
-
}
-
//кнопка ОК
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
textBox1.Text +=
" "
+ listBox1.SelectedItem +
"\r\n"
;
-
}
-
//кнопка Clear
-
private
void
button2_Click(
object
sender, EventArgs e) {
-
textBox1.Clear();
-
}
-
}
}
data:image/s3,"s3://crabby-images/4f7cf/4f7cf46e6153bef000f424c90f4d949f0cedf61f" alt=""
связывание элемента управления с базой данных
На элементе управления раскройте треугольник.
data:image/s3,"s3://crabby-images/6de35/6de3567e54f45af0a85592cd66e6526875078490" alt=""
Выберите флажок Use Data Bound Items.
data:image/s3,"s3://crabby-images/d5de7/d5de7304faf14327f193cf2c4f6dc83544d45f11" alt=""
Раскройте поле с выпадающим списком Data Source.
data:image/s3,"s3://crabby-images/9bdfc/9bdfce95bf5269781a6c139f2fef29401415eeb3" alt=""
Добавьте источник данных. Кликните на Add Project Data Source. Выберите Database.
data:image/s3,"s3://crabby-images/a45ce/a45cec33bcf6dec92ae1d4bd305ddb3d17821c1d" alt=""
Выберите DataSet.
data:image/s3,"s3://crabby-images/5f4cc/5f4cc28bc2895202231593af5d8738a260fe7eab" alt=""
Выберите соединение.
data:image/s3,"s3://crabby-images/9940a/9940a057fa0a225aef7f7539b68d67e9f6cbf43c" alt=""
Запомните имя соединения, если хотите, можете его изменить.
data:image/s3,"s3://crabby-images/f8269/f82699d3521d9fcfc165f23481623b76c442970e" alt=""
Выберите таблицы.
data:image/s3,"s3://crabby-images/d6ac5/d6ac5e98110c9f39da3b3437fae25ac4aa7ec00c" alt=""
После того, как Visual Studio успешно создало соединение с базой данных, опять раскройте поле с выпадающим спискомData Source. Раскройте Other Data Sources. Раскройте starDataSet и выберите таблицу Colors.
data:image/s3,"s3://crabby-images/553b1/553b1348625861ab1d8ca9d890f84db9b77fb85a" alt=""
Раскройте поле с выпадающим списком Display Member и выберите столбец Color. Данные этого столбца будут отображаться в списке. Данные этого столбца можно вывести с помощью свойства SelectedItem.
data:image/s3,"s3://crabby-images/4a45c/4a45c04c0faf11130a4dfcdb2c1dcf6a0c81f1e1" alt=""
Если Вам нужно, то раскройте поле с выпадающим списком Value Member и выберите столбец id. Данные этого столбца можно вывести с помощью свойства SelectedValue.
data:image/s3,"s3://crabby-images/71d71/71d71b5ac4a4e59cd0f73d4daeef064ec624819c" alt=""
Form1.cs
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0044 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
}
-
private
void
Form1_Load(
object
sender, EventArgs e) {
-
// TODO: This line of code loads data into the 'starDataSet.Colors' table. You can move, or remove it, as needed.
-
this
.colorsTableAdapter.Fill(
this
.starDataSet.Colors);
-
}
-
//кнопка OK
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
//ВНИМАНИЕ!!! при работе с базой данных, использование
-
//SelectedItem приводит к выводу не выбранного элемента, а
-
//System.Data.DataRowView
-
textBox1.Text +=
" "
+ listBox1.SelectedItem +
"\r\n"
;
-
textBox2.Text +=
" "
+ listBox1.SelectedValue +
"\r\n"
;
-
textBox3.Text +=
" "
+ listBox1.Text +
"\r\n"
;
-
}
-
//кнопка Clear
-
private
void
button2_Click(
object
sender, EventArgs e) {
-
textBox1.Clear();
-
textBox2.Clear();
-
textBox3.Clear();
-
}
-
}
}
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0044 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
}
-
private
void
Form1_Load(
object
sender, EventArgs e) {
-
// TODO: This line of code loads data into the 'starDataSet.Colors' table. You can move, or remove it, as needed.
-
this
.colorsTableAdapter.Fill(
this
.starDataSet.Colors);
-
}
-
//кнопка OK
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
//ВНИМАНИЕ!!! при работе с базой данных, использование
-
//SelectedItem приводит к выводу не выбранного элемента, а
-
//System.Data.DataRowView
-
textBox1.Text +=
" "
+ listBox1.SelectedItem +
"\r\n"
;
-
textBox2.Text +=
" "
+ listBox1.SelectedValue +
"\r\n"
;
-
textBox3.Text +=
" "
+ listBox1.Text +
"\r\n"
;
-
}
-
//кнопка Clear
-
private
void
button2_Click(
object
sender, EventArgs e) {
-
textBox1.Clear();
-
textBox2.Clear();
-
textBox3.Clear();
-
}
-
}
}
data:image/s3,"s3://crabby-images/6f95a/6f95a5204af92d193dcfb4d5d17b1dba9de93bf2" alt=""
заполняем элемент данными из разных источников данных
В данном примере, наш элемент будет заполнен данными из: коллекции, текстового документа, XML файла, базы данных.
Form1.cs
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
//подключить пространство имен
using
System.IO;
//подключить пространство имен для кодировки
using
System.Text;
//подключить пространство имен
using
System.Xml;
//подключить пространство имен
using
System.Data.SqlClient;
namespace
_0045 {
-
public
partial
class
Form1 : Form {
-
List<
string
> Array =
new
List<
string
> {
-
"red"
,
-
"green"
,
-
"blue"
-
};
-
public
Form1() {
-
InitializeComponent();
-
//заполняем данными из коллекции
-
foreach
(
string
i
in
Array) {
-
listBox1.Items.Add(i);
-
}
-
//заполняем данными из текстового файла
-
//путь
-
string
pathTxt =
@"a.txt"
;
-
//если файл существует
-
if
(File.Exists(pathTxt)) {
-
//создаем байтовый поток и привязываем его к файлу
-
//в конструкторе указываем: путь кодировка
-
using
(StreamReader sr =
new
StreamReader(pathTxt, Encoding.UTF8)) {
-
while
(!sr.EndOfStream) {
-
listBox2.Items.Add(sr.ReadLine());
-
}
-
}
-
}
-
//заполняем данными из XML файла
-
//путь
-
string
pathXml =
@"a.xml"
;
-
//если файл существует
-
if
(File.Exists(pathXml)) {
-
XmlDocument XmlDoc =
new
XmlDocument();
-
//загружаем XML документ
-
XmlDoc.Load(pathXml);
-
//получаем все дочерние элементы корневого элемента
-
//xmlDoc.DocumentElement - корневой элемент
-
foreach
(XmlNode i
in
XmlDoc.DocumentElement.ChildNodes) {
-
foreach
(XmlNode j
in
i.ChildNodes) {
-
listBox3.Items.Add(j.InnerText);
-
}
-
}
-
}
-
//заполняем данными из базы данных
-
//строка подключения к источнику данных
-
string
connectSting =
@"Data Source=.\MSSQLSERVER2012;Initial Catalog=star;Integrated Security=True"
;
-
//sql запрос
-
string
sql =
"select Color from Colors"
;
-
//создаем подключение
-
using
(SqlConnection myConnection =
new
SqlConnection(connectSting)) {
-
//применяем запрос к источнику данных
-
SqlCommand myCommand =
new
SqlCommand(sql, myConnection);
-
try
{
-
//открываем соединение
-
myConnection.Open();
-
//создаем объект для извлечения данных
-
SqlDataReader myReader = myCommand.ExecuteReader();
-
//извлекаем данные
-
while
(myReader.Read()) {
-
listBox4.Items.Add(myReader[0]);
-
}
-
}
-
catch
(Exception ex) {
-
MessageBox.Show(
" Соединение не установлено!"
);
-
}
-
}
-
}
-
}
}
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
//подключить пространство имен
using
System.IO;
//подключить пространство имен для кодировки
using
System.Text;
//подключить пространство имен
using
System.Xml;
//подключить пространство имен
using
System.Data.SqlClient;
namespace
_0045 {
-
public
partial
class
Form1 : Form {
-
List<
string
> Array =
new
List<
string
> {
-
"red"
,
-
"green"
,
-
"blue"
-
};
-
public
Form1() {
-
InitializeComponent();
-
//заполняем данными из коллекции
-
foreach
(
string
i
in
Array) {
-
listBox1.Items.Add(i);
-
}
-
//заполняем данными из текстового файла
-
//путь
-
string
pathTxt =
@"a.txt"
;
-
//если файл существует
-
if
(File.Exists(pathTxt)) {
-
//создаем байтовый поток и привязываем его к файлу
-
//в конструкторе указываем: путь кодировка
-
using
(StreamReader sr =
new
StreamReader(pathTxt, Encoding.UTF8)) {
-
while
(!sr.EndOfStream) {
-
listBox2.Items.Add(sr.ReadLine());
-
}
-
}
-
}
-
//заполняем данными из XML файла
-
//путь
-
string
pathXml =
@"a.xml"
;
-
//если файл существует
-
if
(File.Exists(pathXml)) {
-
XmlDocument XmlDoc =
new
XmlDocument();
-
//загружаем XML документ
-
XmlDoc.Load(pathXml);
-
//получаем все дочерние элементы корневого элемента
-
//xmlDoc.DocumentElement - корневой элемент
-
foreach
(XmlNode i
in
XmlDoc.DocumentElement.ChildNodes) {
-
foreach
(XmlNode j
in
i.ChildNodes) {
-
listBox3.Items.Add(j.InnerText);
-
}
-
}
-
}
-
//заполняем данными из базы данных
-
//строка подключения к источнику данных
-
string
connectSting =
@"Data Source=.\MSSQLSERVER2012;Initial Catalog=star;Integrated Security=True"
;
-
//sql запрос
-
string
sql =
"select Color from Colors"
;
-
//создаем подключение
-
using
(SqlConnection myConnection =
new
SqlConnection(connectSting)) {
-
//применяем запрос к источнику данных
-
SqlCommand myCommand =
new
SqlCommand(sql, myConnection);
-
try
{
-
//открываем соединение
-
myConnection.Open();
-
//создаем объект для извлечения данных
-
SqlDataReader myReader = myCommand.ExecuteReader();
-
//извлекаем данные
-
while
(myReader.Read()) {
-
listBox4.Items.Add(myReader[0]);
-
}
-
}
-
catch
(Exception ex) {
-
MessageBox.Show(
" Соединение не установлено!"
);
-
}
-
}
-
}
-
}
}
data:image/s3,"s3://crabby-images/d42c2/d42c209591faa232996dd131ea6343a0a5e25724" alt=""
программно подогнать ширину элемента под текст
Main.cs
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
WindowsFormsApplication1 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
Graphics G = listBox1.CreateGraphics();
-
float
maxWidth = 0;
-
foreach
(
object
obj
in
listBox1.Items) {
-
float
w = G.MeasureString(obj.ToString(), listBox1.Font).Width;
-
if
(w > maxWidth) {
-
maxWidth = w;
-
}
-
}
-
G.Dispose();
-
listBox1.Width = (
int
)maxWidth;
-
}
-
}
}
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
WindowsFormsApplication1 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
Graphics G = listBox1.CreateGraphics();
-
float
maxWidth = 0;
-
foreach
(
object
obj
in
listBox1.Items) {
-
float
w = G.MeasureString(obj.ToString(), listBox1.Font).Width;
-
if
(w > maxWidth) {
-
maxWidth = w;
-
}
-
}
-
G.Dispose();
-
listBox1.Width = (
int
)maxWidth;
-
}
-
}
}
data:image/s3,"s3://crabby-images/f0839/f0839fd40b2fed9b333fb21e1018a1107160c5d9" alt=""
автоматическая прокрутка списка при добавлении элемента
При добавлении в список нового элемента, список автоматически прокручивается до этого самого элемента, что бы он был виден.
Form1.cs
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0046 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
}
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
listBox1.Items.Add(textBox1.Text);
-
listBox1.TopIndex = listBox1.Items.Count - 1;
-
}
-
}
}
using
System;
using
System.Collections.Generic;
using
System.ComponentModel;
using
System.Data;
using
System.Drawing;
using
System.Linq;
using
System.Text;
using
System.Threading.Tasks;
using
System.Windows.Forms;
namespace
_0046 {
-
public
partial
class
Form1 : Form {
-
public
Form1() {
-
InitializeComponent();
-
}
-
private
void
button1_Click(
object
sender, EventArgs e) {
-
listBox1.Items.Add(textBox1.Text);
-
listBox1.TopIndex = listBox1.Items.Count - 1;
-
}
-
}
}
data:image/s3,"s3://crabby-images/36019/360196b9d54eb447bd490f1dcb6603d7ece55a71" alt=""