मुझे पता है कि सीएसएस के साथ एक संपूर्ण टेबल सेल को लिंक करना संभव है।संपूर्ण तालिका पंक्ति लिंक?
.tableClass td a{
display: block;
}
क्या संपूर्ण तालिका पंक्ति में एक लिंक लागू करने का कोई तरीका है?
मुझे पता है कि सीएसएस के साथ एक संपूर्ण टेबल सेल को लिंक करना संभव है।संपूर्ण तालिका पंक्ति लिंक?
.tableClass td a{
display: block;
}
क्या संपूर्ण तालिका पंक्ति में एक लिंक लागू करने का कोई तरीका है?
मैं Matti से सहमत (यह और "क्लिक" यह पहली कड़ी के लिए लग रहा है) लिंक के साथ सभी तालिका पंक्तियों बनाने के लिए एक सरल jQuery का टुकड़ा है। कुछ सरल जावास्क्रिप्ट के साथ करना आसान होगा। एक त्वरित jQuery उदाहरण कुछ इस तरह होगा:
<tr>
<td><a href="http://www.example.com/">example</a></td>
<td>another cell</td>
<td>one more</td>
</tr>
और
$('tr').click(function() {
window.location = $(this).find('a').attr('href');
}).hover(function() {
$(this).toggleClass('hover');
});
फिर अपने सीएसएस में
tr.hover {
cursor: pointer;
/* whatever other hover styles you want */
}
के माध्यम से बबल करने की आवश्यकता है यह मेरे लिए काम कर सकता है, लेकिन यह क्लिक पर है। क्या यह होवर पर एक लिंक की तरह व्यवहार कर सकता है? धन्यवाद। – santa
यकीन है कि, मैं शायद जो करता हूं वह होवर पर एक वर्ग जोड़ता है और उस वर्ग के भीतर जो भी स्टाइल चाहता है उसे जोड़ता है। मैं अपनी पोस्ट को एक उदाहरण के साथ अपडेट करूंगा। – Jeff
यहां एक लाइव उदाहरण देखें: http://jsfiddle.net/hUMvw/ – Jeff
दुर्भाग्य से, नहीं। एचटीएमएल और सीएसएस के साथ नहीं। एक लिंक बनाने के लिए आपको a
तत्व की आवश्यकता है, और आप एक संपूर्ण तालिका पंक्ति को एक में लपेट नहीं सकते हैं।
निकटतम आप प्राप्त कर सकते हैं प्रत्येक तालिका सेल को जोड़ना। व्यक्तिगत रूप से मैं बस एक सेल को लिंक करता हूं और शेष क्लिक करने योग्य बनाने के लिए जावास्क्रिप्ट का उपयोग करता हूं। वैसे भी कम से कम एक सेल होना अच्छा लगता है जो स्पष्ट रूप से एक लिंक, रेखांकित और सभी की तरह दिखता है।
यहाँ क्लिक करने योग्य
$("table").on("click", "tr", function(e) {
if ($(e.target).is("a,input")) // anything else you don't want to trigger the click
return;
location.href = $(this).find("a").attr("href");
});
@ एलिस्टर: जेएस विधि के साथ कोई अंतराल नहीं होना चाहिए ... AFAIK। इसके अलावा, इन दिनों किसी भी तरह से कोशिकाओं के बीच अंतरिक्ष है –
एके आपको सही याद आ गया है कि आप तालिका पंक्ति के क्लिक ईवेंट को बंद कर रहे थे। (= – Adrian
'tr', 'प्रतिनिधि' जैसे तत्वों की बड़ी संख्या के लिए 'लाइव' –
उदाहरण: http://xxjjnn.com/linktablerow.html
लिंक पूरी पंक्ति:
<table>
<tr onclick="location.href='SomeWherrrreOverTheWebsiiiite.html'">**
<td> ...content... </td>
<td> ...content... </td>
...
</tr>
</table>
Iff आप तो पूरी पंक्ति के लिए माउसओवर पर प्रकाश डाला करने के लिए, चाहते हैं:
<table class="nogap">
<tr class="lovelyrow" onclick="location.href='SomeWherrrreOverTheWebsiiiite.html'">**
...
</tr>
</table>
सीएसएस के लिए निम्नलिखित की तरह कुछ के साथ
, जो तालिका के बीच की खाई को हटा देगा कोशिकाओं और हॉवर पर पृष्ठभूमि बदलने के लिए: Iff आप रेल 3.0.9 का उपयोग कर रहे तो आपको पता चल सकता
tr.lovelyrow{
background-color: hsl(0,0%,90%);
}
tr.lovelyrow:hover{
background-color: hsl(0,0%,40%);
cursor: pointer;
}
table.nogap{
border-collapse: collapse;
}
इस उदाहरण उपयोगी कोड:
सागर में कई मछली है, मछली कई तराजू है, यहाँ एप्लिकेशन/देखें/मछली का स्निपेट है/index.erb
<table>
<% @fishies.each do |fish| %>
<tr onclick="location.href='<%= sea_fish_scales_path(@sea, fish) %>'">
<td><%= fish.title %></td>
</tr>
<% end %>
</table>
@fishies और @sea साथ
अनुप्रयोग में परिभाषित कर रहे हैं /controllers/seas_controller.rb
प्रश्न के पास रेल के साथ कुछ लेना देना नहीं था, और आपके उत्तर का प्रासंगिक हिस्सा इस पर निर्भर नहीं है। – kbanman
कृपया * विशेषताओं पर * क्लिक करने से बचने की कोशिश करें, वे खराब शैली हैं क्योंकि वे मार्कअप और तर्क के बीच अलगाव तोड़ते हैं। – scy
ऑनक्लिक के साथ समस्या यह है कि यह "एक नए टैब में खुलने" के साथ काम नहीं करता है –
मुझे लगता है कि सबसे सरल समाधान सैन्स जावास्क्रिप्ट है और बस प्रत्येक सेल में लिंक डाल रहा है (बशर्ते आपके पास अपनी कोशिकाओं के बीच भारी गलियां न हों या वास्तव में सीमा रेखाएं न हों)। अपने सीएसएस है:
.tableClass td a{
display: block;
}
और फिर सेल प्रति एक लिंक जोड़ने:
<table class="tableClass">
<tr>
<td><a href="#link">Link name</a></td>
<td><a href="#link">Link description</a></td>
<td><a href="#link">Link somthing else</a></td>
</tr>
</table>
उबाऊ लेकिन साफ।
मैंने यहां इस विचार पर विस्तार किया - http://jsfiddle.net/17qygaz1/ –
::before
छद्म तत्व का उपयोग करें। इस तरह से आपको केवल जावास्क्रिप्ट से निपटने या प्रत्येक सेल के लिए लिंक बनाने की आवश्यकता नहीं है। निम्नलिखित table
संरचना
<table>
<tr>
<td><a href="http://domain.tld" class="rowlink">Cell</a></td>
<td>Cell</td>
<td>Cell</td>
</tr>
</table>
सब हम क्या करना है का उपयोग करते हुए एक ब्लॉक तत्व इस मामले में वांछित लिंक (.rowlink
) पर ::before
का उपयोग कर तालिका के पूरे चौड़ाई फैले पैदा करते हैं।
table {
position: relative;
}
.rowlink::before {
content: "";
display: block;
position: absolute;
left: 0;
width: 100%;
height: 1.5em; /* don't forget to set the height! */
}
::before
डेमो में लाल रंग में हाइलाइट किया जाता है ताकि आप देख सकते हैं कि यह क्या कर रहा है।
यह सबकुछ की तुलना में एक बहुत साफ समाधान है। उत्सुक: आप 'td' के लिए 'पैडिंग-टॉप' के साथ इसे कैसे समायोजित करेंगे? – eirikir
@eirikir 'td' के 'पैडिंग-टॉप' के बराबर '.rowlink :: से पहले' नकारात्मक 'मार्जिन-टॉप' जोड़ना मेरे लिए काम करता है। – jzzocc
ग्रेट स्टफ, सबसे अच्छा समाधान मैंने इसे अब तक देखा है। – logos
यह भी निर्भर करता है कि आपको तालिका तत्व का उपयोग करने की आवश्यकता है या नहीं। आप सीएसएस का उपयोग कर एक मेज की नकल और एक एक तत्व पंक्ति बना सकते हैं
<div class="table" style="width:100%;">
<a href="#" class="tr">
<span class="td">
cell 1
</span>
<span class="td">
cell 2
</span>
</a>
</div>
सीएसएस:
.table{display:table;}
.tr{display:table-row;}
.td{display:table-cell;}
.tr:hover{background-color:#ccc;}
नाइस आउट ऑफ़ द बॉक्स सोच। ओपी को विशेष रूप से एक टेबल के अर्थशास्त्र की आवश्यकता नहीं थी। हालांकि, यह वास्तविक सारणी डेटा के लिए एक समाधान नहीं है। –
पूरी पंक्ति लिंक करने के लिए, आप अपने पंक्ति है, जो <tr>
तत्व है पर onclick
समारोह परिभाषित करने की जरूरत और वेब में एक सामान्य क्लिक हाथ करने के लिए माउस सूचक बनाने के लिए tr
तत्व के लिए सीएसएस में एक माउस hover
को परिभाषित:
तालिका में:
<tr onclick="location.href='http://www.google.com'">
<td>blah</td>
<td>blah</td>
<td><strong>Text</strong></td>
</tr>
संबंधित सीएसएस में:
tr:hover {
cursor: pointer;
}
के संभावित डुप्लिकेट [? कैसे एक कड़ी के रूप में एक मेज क्लिक करने योग्य में एक पूरी पंक्ति बनाने के लिए] (http://stackoverflow.com/questions/17147821/how-to -मेक-ए-पूर्ण-पंक्ति-इन-ए-टेबल-क्लिक करने योग्य-ए-लिंक) – PhoneixS